CSS怎么写变量 ?

html-css08

CSS怎么写变量 ?,第1张

CSS变量定义通过在变量名前加 var- 前缀实现,引用时使用 var() 获取变量值。例如:

: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)])

更好理解!