用js动态改变css样式表

用setAttribute方法实现一个页面两份样式表的效果,具体方法如下:

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

<link href="1.css" rel="stylesheet" type="text/css" id="css">

我定义的id是css。

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

<script type="text/javascript">
function change(a){
var css=document.getElementById("css");
if (a==1)
css.setAttribute("href","1.css");
if (a==2)
css.setAttribute("href","2.css");
}
</script>

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

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

<a href="#" onClick="change(1)">1.css</a>
<a href="#" onClick="change(2)">2.css</a>

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

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


还有一种方法:

<script language="javascript">
var b_v = navigator.appVersion;
var IE6 = b_v.search(/MSIE 6/i) != -1;
var IE7 = b_v.search(/MSIE 7/i) != -1;
if (IE6) {
document.write("<link href=""css/neiye_ie6.css"" rel=""stylesheet"" type=""text/css"" id=""cssStyle"" />");
}else{
document.write("<link href=""css/neiye.css"" rel=""stylesheet"" type=""text/css"" id=""cssStyle"" />");
}
</script>




自动化养鸡设备

posted on 2010-10-17 10:48 丁克设计 阅读(13824) 评论(7)  编辑  收藏 所属分类: JavaScript技术文档CSS 技术文档

评论

# re: 用js动态改变css样式表 2012-03-22 14:45 慕义

非常好 thank you   回复  更多评论   

# re: 用js动态改变css样式表 2013-01-21 12:58 刚刚给

sfsdfssf  回复  更多评论   

# re: 用js动态改变css样式表 2013-04-28 13:45 蜗牛网络

没有找到我的答案,辛苦了  回复  更多评论   

# re: 用js动态改变css样式表 2013-05-28 13:26 tshk

修改后 不能事实生效 火狐测试  回复  更多评论   

# re: 用js动态改变css样式表 2013-05-28 13:29 tshk

可以实时生效 刚才写错了 变量名字重复了 好用  回复  更多评论   

# re: 用js动态改变css样式表 2013-12-04 21:20 d

这只是改变外部引用的样式吧
使用Css有三种方法,楼主只说了一种  回复  更多评论   

# re: 用js动态改变css样式表 2015-06-22 20:19 asdf

ding  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航:
 
<2015年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

导航

留言簿(6)

随笔档案

文章分类

文章档案

搜索

最新评论

阅读排行榜