CSS中使用expression只有ie才能识别IE5及其以后版本支持在CSS中使用expression用来把CSS属性和Javascript表达式关联起来这里的CSS属性可以是元素固有的属性也可以是自定义属性
就是说CSS属性后面可以是一段Javascript表达式CSS属性的值等于Javascript表达式计算的结果 在表达式中可以直接引用元素自身的属性和方法也可以使用其他浏览器对象这个表达式就好像是在这个元素的一个成员函数中一样
1.给元素固有属性赋值
下面是定义container容器的宽度
如果<725就为自己的宽度
否则就等于725
相当于max-width:725px;
<style type="text/css" media="screen">
#container { width: expression((documentElement.clientWidth > 725) ? "725px" : "auto" ); }
</style>
<a href="link1.htm" onfocus="this.blur()">link1</a>
<a href="link2.htm" onfocus="this.blur()">link2</a>
<a href="link3.htm" onfocus="this.blur()">link3</a>
粗看或许还体现不出采用expression的优势
但如果你的页面上有几十甚至上百个链接
这时的你还会机械式地Ctrl+C
Ctrl+V么
两者一比较
哪个产生的冗余代码更多呢
采用expression的做法如下
<style type="text/css">
a {star : expression(this.onFocus=this.blur());}
</style>
<a href="link1.htm">link1</a>
<a href="link2.htm">link2</a>
<a href="link3.htm">link3</a>
http://www.cnblogs.com/muguaworld/archive/2011/11/13/2247180.html