浅谈css优化和提高性能的办法

加载性能优化

1、css压缩:将css打包压缩,可以减小文件体积

2、css单一样式:使用margin-left,margin-bottom这种,比使用margin复合属性更快

3、减少使用@import,多使用link

选择器性能优化

1、关键选择器:选择器最后面的部分作为关键选择器,因为css选择符是从右向左进行匹配的,当使用后代选择器的时候,浏览器会遍历所有子元素来确定是否是指定的元素

2、如果规则拥有ID选择器作为其关键选择器,则不要为规则增加标签,过滤掉无关的规则

3、避免使用通配规则*{}

4、尽量少的用标签选择器,而是使用class选择器

5、如果规则拥有ID选择器作为其关键选择器,则不要为规则增加标签

6、尽量将选择器深度降低,最多不要超过三层,更多的使用类来关联标签

7、了解属性的继承,避免重复指定规则

渲染性能优化:

1、慎重使用高性能属性:浮动、定位

2、尽量减少页面重排、重绘

3、去除空规则{}

4、属性值为0时,不加单位

5、属性值为浮动小数0.**,可以省略小数点之前的0

6、标准化各种浏览器前缀:带浏览器前缀的在前。标准属性在后

7、不适用@import前缀

8、选择器优化嵌套,避免层级过深

9、css精灵图、雪碧图

10、正确使用display属性

11、不滥用web字体

可维护性、健壮性:

1、具有相同属性的样式抽离出来,整合并通过class在页面中进行使用,提高css的可维护性

2、样式与内容分离:将css定义到外部css中

相关推荐
品克缤4 分钟前
解决 SVG 作为 CSS 背景图无法 background-size: 100% 100% 拉伸的问题
前端·css·vue.js·css3
小彭努力中5 分钟前
190.Vue3 + OpenLayers 实战:实现地图旋转移动动画 + CSS缩放动画(详解 animate 用法)
前端·css·openlayers·cesium·webgis
Mintopia15 分钟前
从架构起步:如何在软件开发初期决定交付速度与质量
前端·架构
wuhen_n20 分钟前
Prompt工程进阶:少样本与思维链
前端·javascript·ai编程
读忆21 分钟前
NVM 安装低版本 Node.js 失败解决方案
前端·javascript·node.js
Mintopia22 分钟前
AI 改变手敲编程:开发流程被重写的 6 个环节
前端·人工智能
CharlieWang28 分钟前
Vite 终于有了一个很轻的服务端搭档
前端·vite·mcp
new code Boy29 分钟前
Vue3转React速查表
前端·javascript·react.js
@PHARAOH36 分钟前
WHAT - 替代 Express 和 Koa 的现代轻量版 Hono
前端·微服务·express·koa
掘金安东尼1 小时前
低代码真的能替代前端吗?我看了 RollCode 的设计之后有点新想法
前端