• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > CSS代码编写的一些性能优化技巧总结

CSS代码编写的一些性能优化技巧总结

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含CSS,优化等相关知识,佚名 希望在学习及工作中可以帮助到您

CSS规范并没有明确浏览器如何去实现样式系统,仅仅是说明了它们必须这样做。有鉴于此,不同的样式系统引擎可能会拥有完全不同的表现和行为,特别是 Gecko 与 WebKit, 这两个引擎都是开源项目,实现了类似的算法,具有极其相近的优缺点。因此下面介绍的小技巧对于真实世界的 Web 文档将会十分有用。

第一部分内容综合讨论了常见的样式系统是如何分类规则的。接下来的部分包含了书写规则的指南,它利用了前面讨论的样式系统的优点。

样式系统如何拆分规则

样式系统将规则拆分成四个主要类别:

1.ID 规则
2.Class 规则
3.标签规则
4.通用规则
理解这些分类是十分关键的,因为它们是构建规则匹配块的基础。

我在下面的段落中使用术语 关键选择器(key selector)。选择器的最后面的部分即为关键选择器(即用来匹配目标元素的那部分,而不是该元素的祖先元素)。

例如,在下面规则中…

  1. a img,    
  2. div > p,    
  3. h1 + [title] {   
  4.   …   
  5. }  

关键选择器为 img、 p 和 title.

ID 规则

这第一个类别包含了那些将 ID 选择器作为关键选择器的规则。

示例

  1. button#backButton {…} /* This is an ID-categorized rule */  
  2. #urlBar[type="autocomplete"] {…} /* This is an ID-categorized rule */  
  3. treeitem > treerow > treecell#myCell:active {…} /* This is an ID-categorized rule */  

Class 规则

如果一个规则将一个 class 明确作为它的关键选择器,那么它就属于该类别。

示例

  1. button.toolbarButton {…} /* A class-based rule */  
  2. .fancyText {…} /* A class-based rule */  
  3. menuitem > .menu-left[checked="true"] {…} /* A class-based rule */  

标签规则

如果既没有 class 也没有 ID 来明确作为关键选择器,那么接下来的候选者就是 标签 类别。 如果一条规则将一个标签作为它的关键选择器,那么这条规则就属于该类别。

示例

  1. td {…} /* A tag-based rule */  
  2. treeitem > treerow {…} /* A tag-based rule */  
  3. input[type="checkbox"] {…} /* A tag-based rule */  

通用规则

不属于上面那些类别的规则都属于这个类别。

示例

  1. [hidden="true"] {…} /* A universal rule */     
  2. * {…}  /* A universal rule */  
  3. tree > [collapsed="true"] {…} /* A universal rule */  

样式系统如何匹配规则

样式系统从关键选择器开始匹配规则,然后左移(查找规则选择器的任何祖先元素)。只要选择器的子树(substree)一直在检查,样式系统就会持续左移,直到和规则匹配,或者是因为不匹配而放弃该条规则。

规则过滤是你需要学习的最基础的概念。分类存在的意义就是过滤掉无关的规则(这样样式系统就不会浪费时间去匹配它们了)。

这就是能够极大提高性能的关键。对于一个给定的元素,需要匹配的规则越少,样式的解析就会越快。

举个例子,如果一个元素拥有一个 ID,那么只有匹配该 ID 的 ID 规则才会被选中。同理,只有当 Class 规则中的 class 出现在元素上时该规则才被检查。只有当标签规则的标签匹配时该规则才被检查。通用规则始终都会检查。

高效 CSS 指南

避免通用规则

请确保规则不以通用类型选择器作为结束!

不要用标签名或 classes 来限定 ID 规则

如果规则拥有 ID 选择器作为其关键选择器,则不要为规则增加标签名。因为 ID 是唯一的,增加标签只会没必要地减缓匹配过程。

差

  1. button#backButton {…}  

差

  1. .menu-left#newMenuIcon {…}  

好

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06妙用z-index让一个div显示在最前面
  • 2017-12-17position定位,相对定位和绝对定位的区别?
  • 2017-08-06CSS中使用clearfix清除浮动的方法
  • 2017-08-06CSS 关于浮动
  • 2017-08-06Firebug 调试器Web开发者应掌握12个初级使用技巧
  • 2017-08-06css权威指南--笔记(必看)
  • 2017-08-06IE6无法识别伪对象:first-letter和:first-line解决方法
  • 2017-08-06如何为网站设计出色的横幅 为网站设计出色横幅的方法
  • 2017-08-06css+js实现的网页常见选项卡效果
  • 2017-08-06CSS学习之一 CSS样式引入方法

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • CSS 分号引起页面混乱
    • 深入理解css中的align-content属性
    • 全方位了解CSS3的Regions扩展
    • CSS改变网页中鼠标选中文字背景颜色例子
    • css 提示框 CSS实现带箭头的DIV提示框
    • firefox不显示border通过清除float便可解决
    • 手机文本输入框的设计方法介绍(图文)
    • 彻底弄明白CSS3的Media Queries(跨平台设计)
    • 浏览器对于CSS不同类中的同属性不同值优先级问题
    • css hack 记录

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有