在更多的留意了关于 CSS 表达式方面的知识,而这篇文章,是我在看 《高性能网站建设指南》后,以及之前做的一些学习,我想总结下 “为什么尽量避免使用 CSS 表达式”;
什么是 CSS Expression?
CSS Expression (CSS 表达式),是一种使用动态设置 CSS 属性的方式,并且被 IE5 以上的版本所支持,但是 IE8 的标准模式已不再支持 CSS 表达式了[1];
一个简单的 CSS 表达式
body {
background-color: expression( (new Date()).getHours()%2 ? "#B8D4FF" : "#F08A00" )
}
这段代码的作用是能让你页面中 body 的背景色每隔一小时变换一次;
CSS Expression 带来的性能问题
是的,参考 MSDN “关于动态属性” 的文档,你会发现,其实 CSS 表达式还是非常强大的,比如你可以使用 CSS 表达式实现 min-width 属性,隔行换色,模拟 :hover, :before, :after 等伪类;
但是,正式因为 CSS 表达式太强大了,以至于 CSS 表达式带来的严重的性能问题:“为了确保有效性,CSS 表达式会进行频繁的求值”,到底有多频繁?就是在你改变窗口大小,滚动页面甚至移动鼠标都会触发表达式进行求值,如此频繁的求值以至于浏览器的性能收到严重的影响;
关于对 CSS Expression 的性能测试
这个测试的方法是来自于最近一段时间在看的《高性能网站建设指南》中的规则7;
P {
width: expression( setCntr(), document.body.clientWidth<600 ? "600px" : "auto" )
min-width: 600px
border: 1px solid
}
这个方法通过绑定一个 setCntr() 函数到 CSS 表达式上,统计页面执行了多少次的 CSS 表达式,并显示在一个文本框里面;你也可以通过 IE5 ~ IE6 访问http://stevesouders.com/hpws/expression-counter.php 进行测试;
测试结果
页面内有 10 个段落,加载完页面大概执行了 40 次的 CSS 表达式,然后在你改变页面大小,滚动页面,甚至移动鼠标,在我的测试里不动鼠标仍然会执行 CSS 表达式,几万次的求值根本不在话下,而且在点击文本框之后,IE 就已经卡死了;
避免使用 CSS Expression
好吧,这是一个总结;虽然还有对 CSS 表达式进行优化的方法(你可以在参考链接中找到),但是这不是这篇文章要总结的,这篇文章要总结的是为什么尽量避免使用 CSS 表达式;
CSS 表达式虽然强大,但是会给浏览器带来很严重的性能问题,并拖慢网页的加载速度;在可能的前提下,尽量避免使用 CSS 表达式!
CSS 表达式致命的一点是,它执行的频率远远超出了你的想象。理想情况是,我们希望这个表达式在页面加载或刷新的时候执行。事与愿违,只要页面一滚动,它就会重复执行,甚至鼠标移动的时候,它也会执行。要知道80% 的用户喜欢使用鼠标在页面上移动,来帮助他们阅读或者根本就是漫无目的的移动。那就可以想象当用户阅读文章的时候,鼠标的移动量会有多大。因为CSS 表达式在鼠标移动的时候就会执行,所以光看这一个页面,CSS 表达式就执行上千遍,甚至上万遍。这对于用户体验来说简直就是灾难。
一、Css书写顺序:
1.位置属性(position, top, right, z-index, display, float等)
2.大小(width, height, padding, margin)
3.文字系列(font, line-height, letter-spacing, color- text-align等)
4.背景(background, border等)
5.其他(animation, transition等)
二、Css语法:
命名一般为小写英文字母。
为了代码的易读性,在每个声明块的左花括号前添加一个空格。
每条声明语句的 : 后应该插入一个空格。
所有声明语句都应当以分号结尾。最后一条声明语句后面的分号是可选的,但是,如果省略这个分号,你的代码可能更易出错。
对于属性值或颜色参数,省略小于 1 的小数前面的 0 (例如,.5 代替 0.5;-.5px 代替 -0.5px)。
十六进制值应该全部小写,例如,#fff。
尽量使用简写形式的十六进制值,例如,用 #fff 代替 #ffffff。
避免为 0 值指定单位,例如,用 margin: 0 代替 margin: 0px。
Css常用的一些命名:
可参考:CSS 常用命名 - 彼岸时光 - 博客园。
三、Css的引入:
Css的引入一般有两种,link和@import,一般建议使用link引入。这样可以避免考虑@import的语法规则和注意事项,避免产生资源文件下载顺序混乱和http请求过多的烦恼。
四、Css的命名规范(BEM,OOCSS):
什么是BEM:BEM的意思就是块(block)、元素(element)、修饰符(modifier),是由Yandex团队提出的一种前端命名方法论。这种巧妙的命名方法让你的CSS类对其他开发者来说更加透明而且更有意义。
命名约定如下:
.block{} // 块即是通常所说的 Web 应用开发中的组件或模块。每个块在逻辑上和功能上都是相互独立的。
.block__element{} // 元素是块中的组成部分。元素不能离开块来使用。BEM 不推荐在元素中嵌套其他元素。
.block--modifier{} // 修饰符用来定义块或元素的外观和行为。同样的块在应用不同的修饰符之后,会有不同的外观。
优点:
BEM 的优点在于所产生的 CSS 类名都只使用一个类别选择器,可以避免传统做法中由于多个类别选择器嵌套带来的复杂的属性级联问题。在 BEM 命名规则中,所有的 CSS 样式规则都只用一个类别选择器。因此所有样式规则的特异性(specificity)都是相同的,也就不存在复杂的优先级问题。这可以简化属性值的层叠规则。代码清单中的命名规则的好处在于每个 CSS 类名都很简单明了,而且类名的层次关系可以与 DOM 节点的树型结构相对应。
缺点:
这样类名过于长,且复杂。
什么是OOCSS(面向对象CSS):
OOCSS 表示的是面向对象 CSS(Object Oriented CSS),是一种把面向对象方法学应用到 CSS 代码组织和管理中的实践。 OOCSS最关键的一点就是:提高他的灵活性和可重用性。这个也是OOCSS最重要的一点。OOCSS主张是通过在基础组件中添加更多的类,从而扩展基础组件的CSS规则,从而使CSS有更好的扩展性。
OOCSS的优点:
减少CSS代码。
具有清洁的HTML标记,有语义的类名,逻辑性强的层次关系。
语义标记,有助于SEO。
更好的页面优化,更快的加载时间(因为有很多组件重用)。
可扩展的标记和CSS样式,有更多的组件可以放到库中,而不影响其他的组件。
能轻松构造新的页面布局,或制作新的页面风格。
OOCSS的缺点:
OOCSS适合真正的大型网站开发,因为大型网站用到的可重用性组件特别的多,如果运用在小型项目中可能见不到什么成效。所以用不用OOCSS应该根据你的项目来决定。如果没用巧妙的使用,创建组件可能对于你来说是一堆没用的东西,成为一烂摊子,给你的维护带来意想不到的杯具,说不定还是个维护的噩梦。
欢迎到优就业来了解