:root {
var-companyblue: #369
var-lighterblue: powderblue
}
h1 {
color: var(companyblue)
}
h2 {
color: var(lighterblue)
}
以前不行现在可以。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>
<script type="text/javascript" src="jquery-1.8.0.min.js"></script><style type="text/css">
#ul li {
height: 30px
width: 30px
}
</style></head>
<body>
<ul id="ul"></ul>
</body>
<script type="text/javascript">
var str = ""
for(var i = 0i<20i++){
str += "<li>"+i+"</li>"
}
var C1="#123"
var C2="#234"
var C3="#345"
var C4="#456"
var C5="#567" /* 省略剩下的 */
$("#ul").html(str)
$("#ul li").each(function(i){
$(this).css("background-color",new Function("return C"+(i+1))())
})
/* new Function("return C"+i)() 返回对象Ci */
</script>
</html>
大致思想就是这样,不过我建议你把20个颜色变量存放到json中,如:
var color = {C1 : "#123",
C2 : "#234",
C3 : "#345"
}
那么以上代码修改
$(this).css("background-color",color["C"+(i+1)])
更好理解!