CSS中使用expression

来源:互联网 发布:尚硅谷全套java教程 编辑:程序博客网 时间:2024/05/23 19:19

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>
2.给元素自定义属性赋值
例如消除页面上的链接虚线框 通常的做法是
<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+CCtrl+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


0 0