Javascript动态调用css样式表

第一种方法:

第一步:在连接样式表的元素里定义一个id,例如

<link rel=”stylesheet” type=”text/css” href=”css1.css” id=”cssid”>

我定义的id是css。

第二步:写一个js函数,代码如下:

<script type=”text/javascript”>
function change(a){
var css=document.getElementByIdx_x(“cssid”);
if (a==1)
css.setAttribute(“href”,”css1.css”);
if (a==2)
css.setAttribute(“href”,”css2.css”);
if (a==3)
css.setAttribute(“href”,”css3.css”);
}
</script>

这个函数的code可以放在页面的任何地方。

第三步:为改变页面的样式表的连接添加一个函数的触发事件,代码如下:

<a href=”#” οnclick=”change(1)”>我是第一个css1</a>
<a href=”#” οnclick=”change(2)”>我是第二个css2</a>
<a href=”#” οnclick=”change(3)”>我是第三个css3</a>


该效果在IE和FF下均测试通过,相信大家看完后因该非常明了,利用这个方法我们可以让浏览者自己选择需要显示的样式表,比如年老者可以选择一个字体较大的样式表。这里需要注意的两点是:

在这个例子中函数名function后面的名字不能为links或者link,如果为links或者link,样式表将不被改变,具体什么原因我也不大清楚,可能是javascript的保留字符。
另外如果是改变整个页面的样式,你需要在样式表文件里定义body的高度为100%

第二种方式

第一步:在连接样式表的元素里定义一个id,例如

<link rel=”stylesheet” type=”text/css” href=”css1.css” id=”cssid” media=”screen”>

第二步:写一个js函数,代码如下:

<script type=”text/javascript”>
function change1(){
document.getElementByIdx_x(“cssid”).href=”css1.css”;
}
function change2() {
document.getElementByIdx_x(“cssid”).href=”css2.css”;
}
function change3(){
document.getElementByIdx_x(“cssid”).href=”css3.css”;
}
</script>


第三步:为改变页面的样式表的连接添加一个函数的触发事件,代码如下:

<a href=”#” οnclick=”change1()”>我是第一个css1</a>
<a href=”#” οnclick=”change2()”>我是第二个css2</a>
<a href=”#” οnclick=”change3()”>我是第三个css3</a>

第三种方式:

<script type=”text/javascript”>

function loadjscssfile(filename, filetype) {
if (filetype == “js”) { //判断文件类型
var fileref = document.createElement_x(‘script’)//创建标签
fileref.setAttribute(“type”, “text/javascript”)//定义属性type的值为text/javascript
fileref.setAttribute(“src”, filename)//文件的地址
}
else if (filetype == “css”) { //判断文件类型
var fileref = document.createElement_x(“link”)
fileref.setAttribute(“rel”, “stylesheet”)
fileref.setAttribute(“type”, “text/css”)
fileref.setAttribute(“href”, filename)
}
if (typeof fileref != “undefined”)
document.getElementsByTagName_r(“head”)[0].appendChild(fileref)
}

//loadjscssfile(“myscript.js”, “js”) //打开页面时浏览器动态的加载文件
loadjscssfile(“css/shop.css”, “css”)

var rl=<%=(String)ViewState[“col”]%>;

var k = “”;
switch(rl)
{
case 1:
k = “1.css”;
break;
case 2:
k = “2.css”;
break;

}


loadjscssfile(k, “css”) //打开页面时浏览器动态的加载.css 文件
var filesadded = “” //保存已经绑定文件名字的数组变量
function checkloadjscssfile(filename, filetype) {
if (filesadded.indexOf(“[” + filename + “]”) == -1) {// indexOf判断数组里是否有某一项
loadjscssfile(filename, filetype)
filesadded += “[” + filename + “]” //把文件名字添加到filesadded
}
else
alert(“file already added!”)//如果已经存在就提示
}
</script>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值