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

相关推荐
刘一说41 分钟前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
徐同保2 小时前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
刘一说2 小时前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js
一周七喜h3 小时前
在Vue3和TypeScripts中使用pinia
前端·javascript·vue.js
weixin_395448913 小时前
main.c_cursor_0202
前端·网络·算法
东东5163 小时前
基于vue的电商购物网站vue +ssm
java·前端·javascript·vue.js·毕业设计·毕设
MediaTea3 小时前
<span class=“js_title_inner“>Python:实例对象</span>
开发语言·前端·javascript·python·ecmascript
梦梦代码精4 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
0思必得04 小时前
[Web自动化] Selenium执行JavaScript语句
前端·javascript·爬虫·python·selenium·自动化
程序员敲代码吗4 小时前
MDN全面接入Deno兼容性数据:现代Web开发的“一张图”方案
前端