把界面的多个
样式存储到不同的样式文件中,然后通过client的 *** 作(就是单击按钮)动态的加载新的样式文件,实现界面元素样式的批量修改。原理:每个style样式
对象都有一个stylesheet属性,指向该style对象的样式对象。stylesheet对象具有cssText属性,值为样式文本的具体设置内容,可读写,我们可以把这个属性的值设置为一个空的字符串删除样式。stylesheet对象具有addImport方法,用于加载URL文件,其调用格式为:stylesheet.addImport(sURL[,iIndex]),sURL为要加载的CSS文件URL,iIndex为集合中样式
单被请求的位置,缺省为样式单被添加至集合的末尾。示例:本示例通过点击按钮动态的切换页面背景颜色。HTML代码:<html<head<title</title<metaname="GENERATOR" content="Microsoft Visual Studio.NET7.0"<linkhref="stylesheet1.css" type="text/css" rel="stylesheet"id="mycss"<scriptlanguage="javascript"var turnback=falsefunction setCSS(){mycss.styleSheet.cssText=""mycss.styleSheet.addImport(turnback?"stylesheet1.css":"stylesheet2.css")turnback=!turnback}</script</head<body<buttononclick="setCSS()"type="button"切换背景颜色</button</body</htmlStyleSheet1.CSS样式代码:BODY{background-color: Black}StyleSheet2.CSS样式代码:BODY{background-color: maroon}里面说到stylesheet.addImport(sURL[,iIndex]),sURL为要加载的CSS文件URL,iIndex为集合中样式单被请求的位置,缺省为样式单被添加至集合的末尾。那如果要引入STYLE2的话就是mycss.styleSheet.addImport("stylesheet2.css")turnback=false和这里的 *** 作和样式表无关 纯粹是js的一个三目运算符 ?:比如 a=a==b?1:0相当于if(a==b)a=1elsea=0而在你的问题中 turnback 仅仅是个标志 来记录当前样式表的状态turnback=!turnback是令turnback状态翻转(真变假 假变真)他是想用JQ的类选择器.ls选择所有使用这个样式的对象,对它们逐个进行调整,而非更改CSS样式表,所以会有“对象很多”的顾虑。 但问题是,这只是改了那些对象的具体表现样式,而并非改了.LS的设置。如果再出现一个使用.LS风格的元素,它还是老样子,你还需要对这个元素再去调整,治标不治本。而且这种方式也决定了不可能简单地通过一句话就实现。 这样想的人还不少,而如果你看了《如何用JavaScript动态建立或增加CSS样式表》这篇文章之后,相信你很容易就想到如何用一句话来解决这个问题,既简洁高效(浏览器会自动重新设置所有应用这个样式的元素),而且真正的修改了样式设置,新增的使用这个样式的元素将自动应用被修改过的设置。于是,你已经学到了和很多人区分开来的更高阶的知识。下面我把方法具体再说一下: 由于上面的例子,不容易看出效果,我下面另外写了个例子,通过颜色的改变,比较容易看到效果:<STYLE>.theforever {width:50pxcolor:red} #theforever {width:150pxcolor:silver} </STYLE><div class="theforever">这里应该是红色的,但它会被下面的JS通过改变CSS样式设置而变成黄色</div><div id="theforever">这里应该是银灰色的,的确这个不会发生变化,只作为对比</div><script>document.styleSheets[0].cssText=document.styleSheets[0].cssText.replace(/red/g,"yellow")//一句,不就OK了? </script>上面的例子,针对的不是某个特定的样式名称,而是泛泛的颜色(如果你直接挪到含有更为复杂的CSS页面里,其中有不表示颜色的RED字样,这还会导致错误。我对不动脑子的代码拿来主义者一向极其反感,不作过多指示),但如果想要针对特定的样式名称进行更改,同样很容易:
方法一、使用obj.className来修改样式表的类名
方法二、使用obj.style.cssText来修改嵌入式的css
function changeStyle2() {
var obj = document.getElementById("btnB")
obj.style.cssText = "background-color:black display:blockcolor:White
}
评论列表(0条)