CSS 性能优化

目录

  • CSS 性能优化
    • CSS 提高性能的方法
      • 1. 选择器优化
        • 1.1 选择器性能原则
        • 1.2 选择器优化示例
      • 2. 重排(Reflow)和重绘(Repaint)优化
        • 2.1 重排和重绘的概念
        • 2.2 触发重排的操作
        • 2.3 触发重绘的操作
        • 2.4 优化重排和重绘的方法
      • 3. 资源优化
        • 3.1 CSS 文件优化
        • 3.2 图片资源优化
      • 4. 加载优化
        • 4.1 关键 CSS 优化
        • 4.2 媒体查询优化
      • 5. 其他优化建议


CSS 性能优化

CSS 提高性能的方法

1. 选择器优化

1.1 选择器性能原则
  • 避免使用通配符和深层次的嵌套选择器
  • 尽量使用类选择器,减少使用复杂的选择器
  • 避免使用标签选择器作为关键选择器
  • 减少选择器的嵌套层级
  • 优先使用类选择器
  • 避免使用 !important
1.2 选择器优化示例
/* 不推荐 */
div ul li a span {color: red;
}/* 推荐 */
.nav-link {color: red;
}

2. 重排(Reflow)和重绘(Repaint)优化

2.1 重排和重绘的概念
  • 重排(Reflow):当 DOM 元素的尺寸、结构或某些属性发生变化时,浏览器需要重新计算元素的几何属性,将其安放在界面中的正确位置,这个过程称为重排。
  • 重绘(Repaint):当 DOM 元素的样式发生变化,但不影响布局时,浏览器会重新绘制元素,这个过程称为重绘。
2.2 触发重排的操作
  1. 改变元素尺寸

    /* 会触发重排 */
    element.style.width = '100px';
    element.style.height = '100px';
    element.style.padding = '10px';
    element.style.margin = '10px';
    
  2. 改变元素位置

    /* 会触发重排 */
    element.style.position = 'absolute';
    element.style.top = '100px';
    element.style.left = '100px';
    
  3. 改变元素内容

    // 会触发重排
    element.innerHTML = 'new content'
    element.innerText = 'new text'
    
  4. 改变窗口大小

    // 会触发重排
    window.addEventListener('resize', () => {})
    
2.3 触发重绘的操作
  1. 改变颜色相关属性

    /* 只触发重绘 */
    element.style.color = 'red';
    element.style.backgroundColor = 'blue';
    element.style.borderColor = 'green';
    
  2. 改变透明度

    /* 只触发重绘 */
    element.style.opacity = '0.5';
    
  3. 改变阴影

    /* 只触发重绘 */
    element.style.boxShadow = '0 0 10px rgba(0,0,0,0.5)';
    
2.4 优化重排和重绘的方法
  1. 使用 transform 代替位置改变

    /* 不推荐 */
    element.style.left = '100px';
    element.style.top = '100px';/* 推荐 */
    element.style.transform = 'translate(100px, 100px)';
    
  2. 批量修改 DOM

    // 不推荐
    for (let i = 0; i < 100; i++) {element.style.width = i + 'px'
    }// 推荐
    const fragment = document.createDocumentFragment()
    for (let i = 0; i < 100; i++) {const div = document.createElement('div')div.style.width = i + 'px'fragment.appendChild(div)
    }
    document.body.appendChild(fragment)
    
  3. 使用 CSS 类名批量修改样式

    /* 推荐 */
    .active {background: red;color: white;padding: 10px;margin: 5px;
    }
    
  4. 使用绝对定位脱离文档流

    /* 推荐 */
    .animation-element {position: absolute;top: 0;left: 0;
    }
    
  5. 使用 CSS3 硬件加速

    /* 推荐 */
    .hardware-accelerated {transform: translateZ(0);/* 或 */backface-visibility: hidden;/* 或 */perspective: 1000;
    }
    

3. 资源优化

3.1 CSS 文件优化
  • 压缩 CSS 文件
  • 合并多个 CSS 文件
  • 移除未使用的 CSS
  • 使用 CSS 预处理器(Sass/Less)和后处理器(PostCSS)
3.2 图片资源优化
  • 使用 CSS Sprites 合并图片
  • 使用字体图标(Icon Font)代替图片
  • 使用 SVG 代替位图
  • 使用 WebP 格式图片
  • 使用响应式图片

4. 加载优化

4.1 关键 CSS 优化
<!-- 关键 CSS 内联 -->
<style>/* 首屏关键样式 */
</style><!-- 非关键 CSS 异步加载 -->
<linkrel="preload"href="non-critical.css"as="style"onload="this.onload=null;this.rel='stylesheet'"
/>
4.2 媒体查询优化
/* 分离桌面和移动端样式 */
@media screen and (min-width: 768px) {/* 桌面端样式 */
}@media screen and (max-width: 767px) {/* 移动端样式 */
}

5. 其他优化建议

  1. 使用 CSS 变量

    :root {--primary-color: #007bff;--secondary-color: #6c757d;
    }.element {color: var(--primary-color);
    }
    
  2. 使用 CSS Grid 和 Flexbox 布局

    /* 使用 Flexbox */
    .container {display: flex;justify-content: space-between;
    }/* 使用 Grid */
    .grid-container {display: grid;grid-template-columns: repeat(3, 1fr);
    }
    
  3. 使用 will-change 提示浏览器

    .will-animate {will-change: transform;
    }
    
  4. 避免使用 @import

    /* 不推荐 */
    @import 'other.css';/* 推荐 */
    <link rel="stylesheet" href="other.css">
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/82761.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JJ斗地主-注册安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞 …

SON.stringify()和JSON.parse()之间的转换

1.JSON.stringify() 作用&#xff1a;将对象、数组转换成字符串 const obj {code: "500",message: "出错了", }; const jsonString JSON.stringify(obj); console.log(jsonString);//"{"code":"Mark Lee","message"…

MongoDB $type 操作符详解

MongoDB $type 操作符详解 引言 MongoDB 是一款流行的开源文档型数据库,它提供了丰富的查询操作符来满足不同的数据查询需求。在 MongoDB 中,$type 操作符是一个非常有用的查询操作符,它允许用户根据文档中字段的类型来查询文档。本文将详细介绍 MongoDB 的 $type 操作符,…

RagFlow优化代码解析(一)

引子 前文写到RagFlow的环境搭建&推理测试&#xff0c;感兴趣的童鞋可以移步&#xff08;RagFlow环境搭建&推理测试-CSDN博客&#xff09;。前文也写过RagFLow参数配置&测试的文档&#xff0c;详见&#xff08;RagFlow环境搭建&推理测试-CSDN博客&#xff09;…

永磁同步电机控制算法--模糊PI转速控制器

一、原理介绍 在常规的PID控制系统的基础上提出了一种模糊PID以及矢量变换方法相结合的控制系统&#xff0c;经过仿真分析对比证明&#xff1a; 模糊PID控制系统能够有效的提高永磁同步电机的转速响应速度&#xff0c;降低转矩脉动&#xff0c;增强了整体控制系统的抗干扰能力…

MySQL基本操作(续)

第3章&#xff1a;MySQL基本操作&#xff08;续&#xff09; 3.3 表操作 表是关系型数据库中存储数据的基本结构&#xff0c;由行和列组成。在MySQL中&#xff0c;表操作包括创建表、查看表结构、修改表和删除表等。本节将详细介绍这些操作。 3.3.1 创建表 在MySQL中&#…

探索未知惊喜,盲盒抽卡机小程序系统开发新启航

在消费市场不断追求新鲜感与惊喜体验的当下&#xff0c;盲盒抽卡机以其独特的魅力&#xff0c;迅速成为众多消费者热衷的娱乐与消费方式。我们紧跟这一潮流趋势&#xff0c;专注于盲盒抽卡机小程序系统的开发&#xff0c;致力于为商家和用户打造一个充满趣味与惊喜的数字化平台…

89.实现添加收藏的功能的后端实现

实现完查看收藏列表之后&#xff0c;实现的是添加收藏的功能 我的设想是&#xff1a;在对话界面中&#xff0c;如果用户认为AI的回答非常好&#xff0c;可以通过点击该回答对应的气泡中的图标&#xff0c;对该内容进行添加 所以后端实现为&#xff1a; service类中添加&…

OD 算法题 B卷【猴子吃桃】

文章目录 猴子吃桃 猴子吃桃 猴子喜欢吃桃&#xff0c;桃园有N棵桃树&#xff0c;第i棵桃树上有Ni个桃&#xff0c;看守将在H(>N)小时后回来&#xff1b;猴子可以决定吃桃的速度K(个/小时)&#xff0c;每个小时他会选择一棵桃树&#xff0c;从中吃掉K个桃&#xff0c;如果这…

ubuntu 端口复用

需求描述&#xff1a;复用服务器的 80端口&#xff0c;同时处理 ssh 和 http 请求&#xff0c;也就是 ssh 连接和 http 访问服务器的时候都可以指定 80 端口&#xff0c;然后服务器可以正确分发请求给 ssh 或者 http。 此时&#xff0c;ssh 监听的端口为 22&#xff0c;而 htt…

Hive中ORC存储格式的优化方法

优化Hive中的ORC(Optimized Row Columnar)存储格式可显著提升查询性能、降低存储成本。以下是详细的优化方法,涵盖参数配置、数据组织、写入优化及监控调优等维度: 一、ORC核心参数优化 1. 存储与压缩参数 SET orc.block.size=268435456; -- 块大小(默认256MB)…

Vim 设置搜索高亮底色

在 Vim 中&#xff0c;默认搜索命中会高亮显示&#xff0c;方便用户快速定位关键字。但有些用户希望自定义搜索匹配的底色或前景色&#xff0c;以适应不同的配色方案或提高可读性。本文将详细介绍如何修改 Vim 的搜索高亮颜色。 一、Vim 搜索高亮机制 Vim 用内置的高亮组&…

【计算机网络】非阻塞IO——poll实现多路转接

&#x1f525;个人主页&#x1f525;&#xff1a;孤寂大仙V &#x1f308;收录专栏&#x1f308;&#xff1a;计算机网络 &#x1f339;往期回顾&#x1f339;&#xff1a;【计算机网络】非阻塞IO——select实现多路转接 &#x1f516;流水不争&#xff0c;争的是滔滔不息 一、…

vscode使用系列之快速生成html模板

一.欢迎来到我的酒馆 vscode&#xff0c;yyds! 目录 一.欢迎来到我的酒馆二.vscode下载安装1.关于vscode你需要知道2.开始下载安装 三.vscode快速创建html模板 二.vscode下载安装 1.关于vscode你需要知道 Q&#xff1a;为什么使用vscode? A&#xff1a;使用vscode写…

【C/C++】不同防止头文件重复包含的措施

文章目录 #pragma once vs #ifndef 文件宏1 原理层面区别&#xff08;core&#xff09;2 关键区别与优缺点分析3 总结与最佳实践 #pragma once vs #ifndef 文件宏 在 C/C 中&#xff0c;#pragma once 和传统的文件宏守卫 (#ifndef HEADER_H #define HEADER_H ... #endif) 都用…

java-springboot文件上传校验之只允许上传excel文件,且检查不能是脚本或者有害文件或可行性文件

四重验证机制&#xff1a; 文件扩展名检查&#xff08;.xlsx/.xls&#xff09;MIME类型检查文件魔数验证&#xff08;真实文件类型&#xff09;可执行文件特征检测 防御措施&#xff1a; 使用try-with-resources确保流关闭限制文件大小防止DoS攻击使用Apache POI的FileMagic进…

不确定性分析在LEAP能源-环境系统建模中的整合与应用

本内容突出与实例结合&#xff0c;紧密结合国家能源统计制度及《省级温室气体排放编制指南》&#xff0c;深入浅出地介绍针对不同级别研究对象时如何根据数据结构、可获取性、研究目的&#xff0c;构建合适的能源生产、转换、消费、温室气体排放&#xff08;以碳排放为主&#…

高性能分布式消息队列系统(四)

八、客户端模块的实现 客户端实现的总体框架 在 RabbitMQ 中&#xff0c;应用层提供消息服务的核心实体是 信道&#xff08;Channel&#xff09;。 用户想要与消息队列服务器交互时&#xff0c;通常不会直接操作底层的 TCP 连接&#xff0c;而是通过信道来进行各种消息的发布…

QPair 类说明

QPair 类说明 QPair 是一个模板类&#xff0c;用于存储一对数据项。 头文件&#xff1a; cpp #include <QPair> qmake 配置&#xff1a; QT core 所有成员列表&#xff08;包括继承成员&#xff09; 公共类型 类型定义说明first_type第一个元素的类型&#xff…

4.大语言模型预备数学知识

大语言模型预备数学知识 复习一下在大语言模型中用到的矩阵和向量的运算&#xff0c;及概率统计和神经网络中常用概念。 矩阵的运算 矩阵 矩阵加减法 条件&#xff1a;行数列数相同的矩阵才能做矩阵加减法 数值与矩阵的乘除法 矩阵乘法 条件&#xff1a;矩阵A的列数 矩阵…