CSS高级技巧
时间:2023-07-22 20:54:01 | 来源:网站运营
时间:2023-07-22 20:54:01 来源:网站运营
CSS高级技巧:
元素的显示与隐藏
目的:让一个元素在页面中消失或者显示出来。
场景:类似网站广告,当我们点击关闭就不见了,但是我们重新刷新页面,会重新出现。
display 显示(重点)
display 设置或检索对象是否及如何显示。
display: none 隐藏对象 display:block 除了转换为块级元素之外,同时还有显示元素的意思。
特点: 隐藏之后,不再保留位置。
实际开发场景:配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛。
visibility 可见性 (了解)
设置或检索是否显示对象。
visibility:visible ; 对象可视 visibility:hidden; 对象隐藏
特点: 隐藏之后,继续保留原有位置。(相当于停职留薪)
overflow 溢出(重点)
检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。
属性值 | 描述 |
---|
visible | 不剪切内容也不添加滚动条 |
hidden | 不显示超过对象尺寸的内容,超出的部分隐藏掉 |
scroll | 不管超出内容否,总是显示滚动条 |
auto | 超出自动显示滚动条,不超出不显示滚动条 |
overflow实际开发场景:
- 清除浮动。
- 隐藏超出内容,隐藏掉, 不允许内容超过父盒子。
显示与隐藏总结
属性 | 区别 | 用途 |
---|
display | 隐藏对象,不保留位置 | 配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛 |
visibility | 隐藏对象,保留位置 | 使用较少 |
overflow | 只是隐藏超出大小的部分 | 1. 可以清除浮动 2. 保证盒子里面的内容不会超出该盒子范围 |
CSS用户界面样式
所谓的界面样式, 就是更改一些用户操作样式,以便提高更好的用户体验。
- 更改用户的鼠标样式 (滚动条因为兼容性非常差,我们不研究)。
- 表单轮廓等。
- 防止表单域拖拽。
鼠标样式cursor
设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。
属性值 | 描述 |
---|
default | 默认 |
pointer | 小手 |
move | 移动 |
text | 文本 |
not-allowed | 禁止 |
鼠标放我身上查看效果:
<ul> <li style="cursor:default">我是默认</li> <li style="cursor:pointer">我是小手</li> <li style="cursor:move">我是移动</li> <li style="cursor:text">我是文本</li> <li style="cursor:not-allowed">我是禁止</li> </ul>
轮廓线 outline
outline是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。
outline : outline-color ||outline-style || outline-width
最直接的写法是 : outline: 0; 或者 outline: none;
<input type="text" style="outline: 0;"/>
防止拖拽文本域resize
实际开发中,我们文本域右下角是不可以拖拽:
<textarea style="resize: none;">
用户界面样式总结
属性 | 用途 | 用途 |
---|
鼠标样式 | 更改鼠标样式cursor | 样式很多,重点记住 pointer |
轮廓线 | 表单默认outline | outline 轮廓线,我们一般直接去掉,border是边框,我们会经常用 |
防止拖拽 | 主要针对文本域resize | 防止用户随意拖拽文本域,造成页面布局混乱,我们resize:none |
vertical-align 垂直对齐
有宽度的块级元素居中对齐,是margin: 0 auto;
让文字居中对齐,是 text-align: center;
vertical-align 垂直对齐,它只针对于
行内元素或者
行内块元素。
设置或检索对象内容的垂直对其方式。
vertical-align : baseline |top |middle |bottom
注意:
vertical-align 不影响块级元素中的内容对齐,它只针对于
行内元素或者
行内块元素,
特别是行内块元素,
通常用来控制图片/表单与文字的对齐。
图片、表单和文字对齐
默认的图片会和文字基线对齐。
去除图片底侧空白缝隙
图片下方出现空隙原因:
图片或者表单等行内块元素,他的底线会和父级盒子的基线对齐。就是图片底侧会有一个空白缝隙。
解决的方法:
1.给img vertical-align:middle | top| bottom等等。 让图片不要和基线对齐。
img{vertical-align:top;border:0;}
2.给img 添加 display:block; 转换为块级元素就不会存在问题了。
img{display:block;}
溢出的文字省略号显示
white-space
white-space设置或检索对象内文本显示方式。通常我们使用于强制一行显示内容。
text-overflow : clip ;不显示省略标记(...),而是简单的裁切 text-overflow: ellipsis; 当对象内文本溢出时显示省略标记(...)
text-overflow 文字溢出
设置或检索是否使用一个省略标记(...)标示对象内文本的溢出。
text-overflow : clip ;不显示省略标记(...),而是简单的裁切 text-overflow: ellipsis; 当对象内文本溢出时显示省略标记(...)
注意:一定要首先强制一行内显示,再次和overflow属性 搭配使用。
案例:溢出的文字省略号显示<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>溢出的文字省略号显示</title> <style> div { width: 150px; height: 25px; border: 1px solid pink; /*当文字显示不开的时候,自动换行*/ /*white-space: normal;*/ /*1. 要文字强制一行内显示 除非 遇到 br */ white-space: nowrap; /*2. 溢出隐藏*/ overflow: hidden; /*3. 文字溢出 用省略号替代 ellipsis 省略号*/ text-overflow: ellipsis; } </style> </head> <body> <div>欢迎来到前端开发网</div> </body> </html>
展示如下:
总结 溢出的文字省略号显示 三步曲
/*1. 先强制一行内显示文本*/ white-space: nowrap; /*2. 超出的部分隐藏*/ overflow: hidden; /*3. 文字用省略号替代超出的部分*/ text-overflow: ellipsis;
CSS精灵技术(sprite) 重点
为什么需要精灵技术?
图所示为网页的请求原理图,当用户访问一个网站时,需要向服务器发送请求,网页上的每张图像都要经过一次请求才能展现给用户。
一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送请求,这将大大降低页面的加载速度。
为了有效地减少服务器接受和发送请求的次数,提高页面的加载速度。所以出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)。
精灵技术讲解
CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),各个网页元素通常只需要精灵图中不同位置的某个小图,要想精确定位到精灵图中的某个小图。
这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来。
我们需要使用CSS的:
background-image background-repeat background-position
属性进行背景定位, 其中最关键的是使用background-position 属性精确地定位。
代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>体会css精灵技术</title> <style> .duo { width: 36px; height: 42px; background: url(images/jlt.png) no-repeat 0 -192px; } .kuai { width: 36px; height: 42px; background: url(images/jlt.png) no-repeat -41px -192px; } .hao { width: 36px; height: 42px; background: url(images/jlt.png) no-repeat -82px -192px; } .sheng { width: 36px; height: 42px; background: url(images/jlt.png) no-repeat -123px -192px; } p{ overflow: hidden; width: 100%; height: 42px; line-height: 42px; font-size: 18px; font-weight: 700; text-overflow: ellipsis; white-space: nowrap; color: #444; } body{ margin: 0 auto; width: 1170px; } div{ float: left;width: 279px; } p{ margin-left: 47px; margin-top: -65px; } </style> </head> <body> <div> <h5 class="duo"></h5> <p>品类齐全,轻松购物</p> </div> <div> <h5 class="kuai"></h5> <p>多仓直发,极速配送</p> </div> <div> <h5 class="hao"></h5> <p>正品行货,精致服务</p> </div> <div> <h5 class="sheng"></h5> <p>天天低价,畅选无忧</p> </div> </body> </html>
精灵技术使用的核心总结
首先我们知道,css精灵技术主要针对于背景图片,插入的图片img 是不需要这个技术的。
- 精确测量,每个小背景图片的大小和 位置。
- 给盒子指定小背景图片时, 背景定位基本都是 负值。
制作精灵图(了解)
CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),那我们要做的,就是把小图拼合成一张大图。
大部分情况下,精灵图都是网页美工做。
友情提示:小公司背景图片很少的情况,没有必要使用精灵技术,维护成本太高。 如果是背景图片比较多,可以建议使用精灵技术。
前端开www.qdkf.wang