用JS实现一个页面两份样式表

作者:sunritz 来源:蓝色理想 时间:2008-07-23 12:37:00 

今天研究了一下JS的用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下均测试通过,相信大家看完后因该非常明了,利用这个方法我们可以让浏览者自己选择需要显示的样式表,比如年老者可以选择一个字体较大的样式表。这里需要注意的两点是:

  1. 在这个例子中函数名function后面的名字不能为links或者link,如果为links或者link,样式表将不被改变,具体什么原因我也不大清楚,可能是javascript的保留字符。

  2. 另外如果是改变整个页面的样式,你需要在样式表文件里定义body的高度为100%

标签:样式,js,css
0
投稿

猜你喜欢

  • 如何绝对获知浏览器类型?

    2009-12-16 18:58:00
  • 分享到豆瓣、百度空间、新浪微博的js代码

    2011-03-17 12:58:00
  • SQL Server 2008 到底需要使用哪些端口?

    2012-11-30 20:29:41
  • 轻松掌握如何从命令行启动mysqld服务器

    2008-12-31 15:47:00
  • 交互设计师心得——核心竞争力

    2010-01-19 13:45:00
  • 根据表中数据生成insert语句的存储过程

    2008-11-10 12:13:00
  • 分享我们的select控件设计过程

    2009-06-16 18:04:00
  • ASP内置对象Request和Response用法详解

    2007-09-14 10:35:00
  • AXObject解决IE需要激活 ActiveX 控件方法

    2007-11-08 12:16:00
  • 经典的退出浏览器弹窗代码

    2008-07-30 12:48:00
  • java.sql.SQLException: 内部错误: Unable to construct a Datum from the specified input

    2010-07-16 13:23:00
  • ASP实现防止网站被采集代码

    2011-03-25 10:40:00
  • ASP网站Server object error的解决办法

    2008-11-07 15:57:00
  • Oracle9i 动态SGA,PGA特性探索

    2009-04-24 12:39:00
  • MySQL的存储过程写法和Cursor的使用

    2008-12-03 15:55:00
  • 解决MySQL不允许从远程访问的方法

    2010-03-18 15:39:00
  • 为google量身定做的sitemap生成代码asp版

    2011-04-06 10:43:00
  • 专家教你安装 MySQL的与MySQL GUI Tools

    2012-01-29 17:59:05
  • oracle join on 数据过滤问题

    2009-07-14 21:17:00
  • CSS实现HTML元素透明的那些事

    2010-02-01 12:34:00
  • asp之家 网络编程 m.aspxhome.com