浅谈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中

相关推荐
LinXunFeng8 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
乘风gg12 小时前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭12 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒12 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭12 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
Hyyy13 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
Gatlin14 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
Pedantic14 小时前
本地通知(Local Notifications)学习笔记
前端
森蓝情丶15 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
爱勇宝15 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员