CSS高级技巧
一、元素的显示与隐藏
1、目的:
让一个元素在页面中消失,但是不在文档源码中删除。
2、场景:
是网站广告,当我们点击类似关闭不见了,但是我们重新刷新页面,会重新出现。
(一)、display显示(重点)
1、display设置或检索对象是否及如何显示
display: none 隐藏对象
display: block 除了转换为块级元素之外,同时还有显示元素的意思
2、特点:隐藏之后,不再保留位置。
(二)visibility 可见性(了解)
1、设置或检索是否显示对象
visibility: visible; 对象可视
visibility: hidden; 对象隐藏
2、特点:隐藏之后,继续保留原有位置
(三)overflow溢出(重点)
1、检索或设置当对象的内容超过其指定高度及宽度时如何管理内容
属性值 | 描述 |
visible | 不剪切内容也不添加滚动条 |
hidden | 不显示超过对象尺寸的内容,超出的部分隐藏掉 |
scroll | 不管超出内容否,总是显示滚动条 |
auto | 超出自动显示滚动条,不超出不显示滚动条 |
(四)显示与隐藏总结
属性 | 区别 | 用途 |
display | 隐藏对象,不保留位置 | 配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单,应用极为广泛 |
visibility | 隐藏对象,保留位置 | 使用较少 |
overflow | 只是隐藏超出大小的部分 | 1.可以清除浮动 2.保证盒子里面的内容不会超出该盒子范围 |
二、CSS用户界面样式
1、所谓的界面样式,就是更改一些用户操作样式,以便提高更好的用户体验
(1)更改用户的鼠标样式(滚动条因为兼容性非常差,我们不研究);
(2)表单轮廓等;
(3)防止表单域拖拽
(一)鼠标样式cursor
设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。
属性值 | 描述 |
default | 小白 默认 |
pointer | 小手 |
move | 移动 |
text | 文本 |
not-allowed | 禁止 |
(二)轮廓线outline
1、是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用
outline : outline-color || outline-style || outline-width
但是我们都不关心可以设置多少,我们平时都是去掉的
2、最直接的写法是: outline: 0; 或者 outline: none;
<input type="text" style="outline: 0;"/>
(三)、防止拖拽文本域resize
实际开发中,我们文本域右下角是不可以拖拽:
<textarea style="resize: none;"></textarea>
(四)用户界面样式总结
属性 | 用途 | 用途 |
鼠标样式 | 更改鼠标颜色cursor | 样式很多,重点记住pointer |
轮廓线 | 表单默认outline | outline 轮廓线,我们一般直接去掉,border是边框,我们会经常用 |
防止拖拽 | 主要针对文本域resize | 防止用户随意拖拽文本域,造成页面布局混乱,我们resize:none; |
三、vertical-align 垂直居中
1、有宽度的块级元素居中对齐,是margin:0 auto;
2、让文字居中对齐,是text-align:center;
3、vertical-align 垂直居中,它只针对行内元素或者行内块元素
vertical-align: baseline | top |middle |bottom
4、设置或检索对象内容的垂直对齐方式
(1)注意:
vertical-align 不影响块级元素中的内容对齐,它只针对于行内元素或者行内块元素
特别是行内块元素,通常用来控制图片/表单与文字对齐
(一)图片、表单和文字对齐
所以我们知道,我们可以通过vertical-align 控制图片与文字的垂直关系了,默认的图片会和文字基线对齐
(二)去除图片底侧空白缝隙
1、原因:
(1)图片或者表单等行内块元素,它的底线会和父级盒子的基线对齐,就是图片底侧会有一个空白缝隙。
(2)解决的方法就是:
①给img vertical-align:middle | top | bottom等等,让图片不要和基线对齐;
②给img 添加 display: block; 转换为块级元素就不会存在问题了。
四、溢出的文字省略号显示
1、white-space
(1)white-space设置或检索对象内文本显示方式,通常我们使用于强制一行显示内容
white-space:normal; 默认处理方式
white-space:nowrap; 强制在同一行内显示所有文本,直到文本结束或者遭遇br标签对象才换行。
2、text-overflow 文字溢出
(1)设置或检索是否使用一个省略标记(...)标示对象内文本的溢出
text-overflow : clip; 不显示省略标记(...),而是简单的裁切
text-overflow : ellipsis; 当对象内文本溢出时显示省略标记(...)
(2)注意:
一定要首先强制一行内显示,再和overflow属性 搭配使用
3、总结三部曲
(1)先强制一行内显示文本
white-space: nowrap;
(2)超出的部分隐藏
overflow: hidden;
(3)文本用省略号代替超出的部分
text-overflow: ellipsis;
五、CSS精灵技术(sprite)重点
(一)为什么需要精灵技术
1、图所示为网页的请求原理图,当用户访问一个网站时,需要向服务器发送请求,网页上的每张图像都要经过一次请求才能展示给用户。
2、然而,一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送请求,这将大大降低页面的加载速度。
3、为什么需要精灵技术:
为了有效地减少服务器接受和发送请求的次数,提高页面的加载速度。
出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)
(二)精灵技术讲解
1、CSS精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素通常只需要精灵图中不同位置的某个小图,要想精确定位到精灵图中的某个小图。
这样,当用户访问该页面时,只需要向服务发送一次请求,网页中的背景图像即可全部展示出来。
2、我们需要使用CSS的
(1)background-image;
(2)background-repeat;
(3)background-position属性进行背景定位;
(4)其中最关键的是使用background-position属性精确地定位
(三)精灵技术使用的核心总结
首先我们知道,CSS精灵技术主要针对于背景图片,插入的图片img是不需要这个技术的
1、精确测量,每个小背景图片的大小和位置;
2、给盒子指定小背景图片时,背景定位基本都是负值。
(四)制作精灵图(了解)
1、CSS精灵图其实是将网页中一些背景图像整合到一张大图中(精灵图),那我们要做的,就是把小图拼合成一张大图。
大部分情况下,精灵图都是网页美工做。
2、我们精灵图上放的都是小的装饰性质的背景图片,插入图片不能往上放,
我们可以横向摆放也可以纵向摆放,但是每个图片之间留有适当的空隙,
在我们精灵图的最低端,留一片空隙,方便我们以后添加其他精灵图。
3、小公司,背景图片很少的情况,没有必要使用精灵技术,维护成本太高,如果是背景图片比较多,可以建议使用精灵技术。
六、滑动门
(一)滑动门出现的背景
1、制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,最大的问题是里面的字数不一样多,咋办?
2、为了方便各种特殊形状的背景能够适应元素中文本内容的多少,出现了CSS滑动门技术,它从新的角度构建页面,便于各种特殊形状的背景能够自由拉伸滑动,以适应元素内部的文本内容,可用性更强。最常见于各种导航栏的滑动门。
(二)核心技术
1、核心技术就是利用CSS精灵(主要是背景位置)和盒子padding撑开宽度,以便能适应不同字数的导航栏。
一般经典布局都是这样的:
2、CSS样式
* {
padding:0;
margin:0;
}
body {
background: url(images/wx.jpg) repeat-x;
}
father {
padding-top:20px;
}
li {
padding-left: 16px;
height:33px;
float:left;
line-height:33px;
margin:0 10px;
background:url(images/to.png) no-repeat left;
}
a {
padding-right:16px;
height:33px;
display:inline-block;
color:#fff;
background:url(images/to.png) no-repeat right;
text-decoration:none;
}
li:hover,
li:hover a {
background-image:url(images/ao.png);
}
3、总结:
(1)a 设置 背景左侧,padding撑开合适宽度;
(2)span 设置 背景右侧,padding撑开合适宽度,剩下由文字继续撑开宽度;
(3)之所以a 包含 span 就是因为整个导航都是可以点击的
七、拓展
(一)margin负值之美
1、负边距+定位:水平垂直居中
一个绝对定位的盒子,利用 父级盒子的50%,然后 往左(上)走 自己宽度的一半,可以实现盒子的水平垂直居中
2、压住盒子相邻边框
(二)CSS三角形之美
做法:
1、我们用css边框可以模拟三角效果;
2、宽度高度为0;
3、我们4个边框都要写,只保留需要的边框颜色,其余的不能省略,都改写为transparent 透明就好了;
4、为了照顾兼容性,低版本的浏览器,加上 font-size:0; line-height: 0;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」