• 用js动态改变css样式表


    用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>

  • 相关阅读:
    Intel 编译器 线程安全检查 真心的很详细 转
    当前软件设计分析
    当代并行机系统
    多人游戏服务器
    ACE源代码目录结构
    (转!)Z buffer和W buffer简介
    数据库-视图(View)详解
    推荐一个vs自带工具分析代码的复杂度
    SCOPE_IDENTITY的用法
    vs2013开发调试cocos2d-x-Lua工程项目
  • 原文地址:https://www.cnblogs.com/natureclove/p/js_change_css.html
Copyright © 2020-2023  润新知