一文大白话讲清楚CSS性能优化

文章目录

  • 一文大白话讲清楚CSS性能优化
  • 1.讲性能优化肯定得先说清楚要什么性能,才能知道怎么优化
  • 2.优化方向之一:快速地编写
    • [2.1 使用预编译语言](#2.1 使用预编译语言)
    • [2.2 适用速记属性](#2.2 适用速记属性)
    • [2.3 使用CSS原生变量](#2.3 使用CSS原生变量)
    • [2.4 其他](#2.4 其他)
  • [3. 优化方向之二:快速的运行](#3. 优化方向之二:快速的运行)
    • [3.1 快速运行的前提是快速的加载](#3.1 快速运行的前提是快速的加载)
      • [3.1.1 要想加载快,那首先CSS文件体积小肯定很重要](#3.1.1 要想加载快,那首先CSS文件体积小肯定很重要)
      • [3.1.2 尽量避免使用import](#3.1.2 尽量避免使用import)
      • [3.1.3 首屏使用内联CSS](#3.1.3 首屏使用内联CSS)
      • [3.1.4 异步加载CSS](#3.1.4 异步加载CSS)
    • [3.2 想要运行快,高耗时耗性能的事少干](#3.2 想要运行快,高耗时耗性能的事少干)
      • [3.2.1 减少回流和重绘](#3.2.1 减少回流和重绘)
      • [3.2.2 合理使用选择器](#3.2.2 合理使用选择器)
      • [3.2.3 减少使用昂贵属性](#3.2.3 减少使用昂贵属性)
      • [3.2.4 优化媒体查询](#3.2.4 优化媒体查询)
    • [3.3 其他](#3.3 其他)
  • [4. 优化方向三:快速地维护](#4. 优化方向三:快速地维护)
    • [4.1 基础是能快速看懂](#4.1 基础是能快速看懂)
    • [4.2 关键是二开要高效](#4.2 关键是二开要高效)

一文大白话讲清楚CSS性能优化

1.讲性能优化肯定得先说清楚要什么性能,才能知道怎么优化

  • 我们CSS要什么性能,三句话概括
  1. 快速地编写
  • 不写重复无用的代码,提高代码的可复用性
  1. 快速地运行
  • 快速地加载,快速地运行
  1. 快速地维护
  • 阅读顺畅,二开高效
  • 当然有时候要在三个快之间做平衡,不是哪个越快整体越好,而是三者之间寻找一个平衡的点,既快又好的效果

2.优化方向之一:快速地编写

2.1 使用预编译语言

2.2 适用速记属性

  • 如果设置margin的四个属性,可以直接margin:上 右 下 左;不需要margin-top;margin-right;margin-left;margin-bottom这样一个一个设置

2.3 使用CSS原生变量

  • 我们可以使用CSS原生变量,提高代码的复用性,进而提高代码编写速度

2.4 其他

3. 优化方向之二:快速的运行

3.1 快速运行的前提是快速的加载

3.1.1 要想加载快,那首先CSS文件体积小肯定很重要

  1. 删除无用的代码
  2. 使用css压缩工具压缩CSS代码
  3. 使用css Sprite
  4. 其他

3.1.2 尽量避免使用import

  • import会影响浏览器的并行下载,使得页面在加载时增加额外的延迟,而且多个import有可能会导致下载顺序错乱

3.1.3 首屏使用内联CSS

  • 为了使首屏更快的呈现给用户,可以使用内联css,提前css渲染时间

3.1.4 异步加载CSS

  • 可以使用异步加载css

3.2 想要运行快,高耗时耗性能的事少干

3.2.1 减少回流和重绘

3.2.2 合理使用选择器

  • CSS的匹配规则是从右往左,譬如#title .div h2匹配的时候,先找到h2;然后去除上一层不是.div的元素;然后再往上去除不是#title的元素。如果嵌套的层级太多,匹配花费的事件会很大

3.2.3 减少使用昂贵属性

  • 在页面重绘时,向box-shadow / border-radius / filter / opacity 等昂贵属性会降低浏览器的渲染能力

3.2.4 优化媒体查询

  • 媒体查询的预设可以更高效的适配不同的设备

3.3 其他

4. 优化方向三:快速地维护

4.1 基础是能快速看懂

  1. 设计良好的CSS结构
  2. 编写良好的注释代码
  3. 合理的使用预编译语言

4.2 关键是二开要高效

  • 二开要高效,就是要快速的更改所有需要更改的代码,所以问题还是回到了提高代码的复用性上,可以使用变量,预编译语言等,提高二开效率
相关推荐
threelab1 分钟前
二维热力图技术实现分析
javascript
唐懒猫4 分钟前
使用 HTML + JavaScript 实现手写签名功能
前端·javascript·html
lu9up5 分钟前
业务表异常阻塞导致接口超时处理案例
数据库·性能优化
苏打水com11 分钟前
Day4-6 CSS 进阶 + JS 基础 —— 实现 “交互效果 + 样式复用”(对标职场 “组件化思维” 入门)
javascript·css·交互
亿元程序员14 分钟前
其实Creator里面这个裁剪代码的功能很好用,建议试试
前端
感谢地心引力16 分钟前
【Chrome-Edge-Firefox】浏览器插件开发
前端·chrome·edge·firefox
qq_2965446520 分钟前
安卓版Google(谷歌地球),安卓谷歌(Google)地图,谷歌翻译,谷歌(Chrome)浏览器,手机版Edge,浏览器等安卓版浏览器下载
前端·chrome
今天也想MK代码21 分钟前
JS 注入机制深度解析
java·前端·javascript
一字白首25 分钟前
Vue 进阶,指令补充 + computed+watch
前端·javascript·vue.js
暮之沧蓝25 分钟前
React(18-19)总结
前端·react.js·前端框架