博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
为什么尽量避免使用 CSS 表达式
阅读量:4677 次
发布时间:2019-06-09

本文共 1468 字,大约阅读时间需要 4 分钟。

http://loo2k.com/blog/why-avoid-css-expression/

七月 12, 2011 10:28 | |

以前曾经发表过一篇文章 ,讲的是使用 CSS 表达式来解决 IE6 无法使用 positio: fixed; 固定定位的问题;在文章发表之后的到现在,一些朋友告诉我 CSS 表达式可能会影响到网站的性能;

经过这些朋友们的提醒,我更多的留意了关于 CSS 表达式方面的知识,而这篇文章,是我在看 《》后,以及之前做的一些学习,我想总结下 “为什么尽量避免使用 CSS 表达式”;

什么是 CSS Expression?

CSS Expression (CSS 表达式),是一种使用动态设置 CSS 属性的方式,并且被 IE5 以上的版本所支持,但是 IE8 的标准模式已不再支持 CSS 表达式了

一个简单的 CSS 表达式

  1. body {
  2. background-color: expression((new Date()).getHours()%2?"#B8D4FF":"#F08A00");
  3. }

这段代码的作用是能让你页面中 body 的背景色每隔一小时变换一次;

CSS Expression 带来的性能问题

是的,参考 MSDN “” 的文档,你会发现,其实 CSS 表达式还是非常强大的,比如你可以使用 CSS 表达式实现 min-width 属性,隔行换色,模拟 :hover, :before, :after 等伪类;

但是,正式因为 CSS 表达式太强大了,以至于 CSS 表达式带来的严重的性能问题:“为了确保有效性,CSS 表达式会进行频繁的求值”,到底有多频繁?就是在你改变窗口大小,滚动页面甚至移动鼠标都会触发表达式进行求值,如此频繁的求值以至于浏览器的性能收到严重的影响;

关于对 CSS Expression 的性能测试

这个测试的方法是来自于最近一段时间在看的《》中的规则7;

  1. P {
  2. width: expression( setCntr(), document.body.clientWidth<600?"600px":"auto");
  3. min-width:600px;
  4. border:1px solid;
  5. }

这个方法通过绑定一个 setCntr() 函数到 CSS 表达式上,统计页面执行了多少次的 CSS 表达式,并显示在一个文本框里面;你也可以通过 IE5 ~ IE6 访问 进行测试;

测试结果

页面内有 10 个段落,加载完页面大概执行了 40 次的 CSS 表达式,然后在你改变页面大小,滚动页面,甚至移动鼠标,在我的测试里不动鼠标仍然会执行 CSS 表达式,几万次的求值根本不在话下,而且在点击文本框之后,IE 就已经卡死了;

避免使用 CSS Expression

好吧,这是一个总结;虽然还有对 CSS 表达式进行优化的方法(你可以在参考链接中找到),但是这不是这篇文章要总结的,这篇文章要总结的是为什么尽量避免使用 CSS 表达式;

CSS 表达式虽然强大,但是会给浏览器带来很严重的性能问题,并拖慢网页的加载速度;在可能的前提下,尽量避免使用 CSS 表达式!

参考链接
脚注

More Articles about

,

posted on
2012-03-20 11:15 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/-clq/archive/2012/03/20/2407588.html

你可能感兴趣的文章
PAT-1134. Vertex Cover (25)
查看>>
git 命令图解
查看>>
分布式存储系统可靠性系列三:设计模式
查看>>
this关键字的由来及使用
查看>>
两个时间相差多少 .net中的timespan应用
查看>>
递归 换零钱问题——由打靶子问题引申
查看>>
Python-函数基础
查看>>
Extensible Messaging and Presence Protocol (XMPP) 简介
查看>>
Farm Irrigation
查看>>
windows平板的开发和选型
查看>>
无平方因子的数(数论初步) By ACReaper
查看>>
C语言截取字符串
查看>>
如何查自己的账单
查看>>
JAVA8学习笔记(二)----三个预定义接口
查看>>
JDBC连接各种数据库的字符串
查看>>
构建之法阅读笔记06
查看>>
CentOS minimal新装配置笔记
查看>>
压缩映象原理的一个应用
查看>>
Aurora — 一个在 MSOffice 内输入 LaTeX 公式的很好用插件
查看>>
关于sql优化的一个小总结
查看>>