在css expression中使用javascript表达式。css属性根据javascript表达式的计算结果来设置。
css expression在其它浏览器中不起作用,因此在跨浏览器的编码中单独针对ie设置时会比较有用。
从ie5开始支持css expression。我们看下面的代码:
background-color: expression( (new date()).gethours()%2 ? "#f00" : "#00f" );
上面的代码是使用css expression,实现隔一个小时切换一次背景颜色。
css expression的问题就在于它的计算频率要比想象的多出很多。不仅仅是在页面显示和缩放时,就是在页面滚动、乃至移动鼠标时都会要重新计算一次。给css expression增加一个计数器可以跟踪表达式的计算频率。在页面中随便移动鼠标都可以轻松达到10000次以上的计算量。
一个减少css expression计算次数的方法就是使用一次性的表达式,它在第一次运行时将结果赋给指定的样式属性,并用这个属性来代替css expression。
如果样式属性必须在页面周期内动态地改变,使用事件句柄来代替css表达式是一个可行办法。如果必须使用css expression,一定要记住它们要计算成千上万次并且可能会对你页面的性能产生影响。不要让您的用户感觉打开你的页面,机器会变的很慢。
如对本文有疑问,
点击进行留言回复!!
相关文章:
-
-
-
-
-
-
-
-
-
-
-
CSS中的四种定位区别详解
我们都知道,前端开发里面的css中常用的定位方式有普通定位,相对定位,绝对定位、固定定位定位这四种。但是很多零基础的前端小白都不知道这4种定位方式都有什么作用和...
[阅读全文]
网友评论