1.精灵图(重点)
1.1 为什么需要精灵图
一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接收和发送请求图片,造成服务器请求压力过大,这将大大降低页面的加载速度。
为什么使用精灵图(目的)
为了有效地减少服务器接收和发送请求的次数,提高页面的加载速度,出现了 CSS精灵技术(也称 CSS Sprites、CSS 雪碧)
核心原理
将网页中的一些小背景图像整合到一张大图中,这样服务器只需要一次请求就可以了。
1.2 精灵图(sprites)的使用
1、精灵技术主 要针对于背景图片使用。就是把多个小背景图片整合到一张大图片中。
2、这个大图片也称为 sprites 精灵图 或者 雪碧图
3、移动背景图片位置,此时可以使用 background-position 。
4、移动的距离就是这个目标图片的x和y坐标。注意网页中的坐标有所不同5、因为一般情况下都是往上往左移动,所以数值是负值。
6、使用精灵图的时候需要精确测量,每个小背景图片的大小和位置。
使用精灵图核心总结:
1、精灵图主要针对于小的背景图片使用,
2、主要借助于背景位置来实现-background-position 。
3、一般情况下精灵图都是负值。(千万注意网页中的坐标:x轴右边走是正值,左边走是负值, y轴同理。)
2.字体图标
2.1 字体图标的产生
字体图标使用场景: 主要用于显示网页中通用、常用的一些小图标。
精灵图是有诸多优点的,但是缺点很明显。
1、图片文件还是比较大的。
2、图片本身放大和缩小会失真。
3、一旦图片制作完毕想要更换非常复杂。
字体图标可以为前端工程师提供一种方便高效的图标使用方式,展示的是图标,本质属于字体。
2.2 字体图标的优点
轻量级:一个图标字体要比一系列的图像要小。一旦字体加载了,图标就会马上渲染出来,减少了服务器请求
灵活性:本质其实是文字,可以很随意的改变颜色、产生阴影、透明效果、旋
转等兼容性:几乎支持所有的浏览器,请放心使用。注意: 字体图标不能替代精灵技术,只是对工作中图标部分技术的提升和优化。
总结:1、如果遇到一些结构和样式比较简单的小图标,就用字体图标。[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AqJzAn0W-1611744474837)(images/1571519724473.png)]
2、如果遇到一些结构和样式复杂一点的小图片,就用精灵图
使用步骤
字体图标是一些网页常见的小图标,我们直接网上下载即可。因此使用可
1、字体图标的下载
2、字体图标的引入(引入到我们html页面中)
3、字体图标的追加(以后添加新的小图标)
2、CSS 三角
2.1 介绍
网页中常见一些三角形,使用 CSS 直接画出来就可以,不必做成图片或者字体图标。
div {
width:0;
height:0;
border:50px solid transparent;
border-color:red green blue black;
line-height:0;
font-size:0;
}
1、我们用css 边框可以模拟三角效果
2、宽度高度为0
3、我们4个边框都要写,只保留需要的边框颜色,其余的不能省略,都改为3、我们4个边框都要写
transparent 透明就好了
4、为了照顾兼容性 低版本的浏览器,加上 font-size:0; line-height: 0;
4.CSS 用户界面样式
什么是界面样式
所谓的界面样式,就是更改一些用户操作样式,以便提高更好的用户体验。
·更改用户的鼠标样式。
·表单轮廓。
·防止表单域拖拽
4.1 鼠标样式 cursor
li{
cursor:pointer:
}
设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状
属性值 | 描述 |
---|---|
default | 小白 默认 |
pointer | 小手 |
move | 移动 |
no-drop | 禁止 |
text | 文本 |
4.2 轮廓线 outline
给表单添加 outline: 0; 或者 outline: none;样式之后,就可以去掉默认的蓝色边框。
input{
outline: none;}
4.3 防止拖拽文本域 resize
实际开发中,我们文本域右下角是不可以拖拽的。
textarea{
resize:none;
}