今天研究了一下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可以放在頁面的任何地方。
第三步:為改變頁面的樣式表的連接添加一個函數的觸發(fā)事件,代碼如下:
<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%
本文鏈接:http://www.95time.cn/tech/web/2008/5980.asp
出處:藍色理想
責任編輯:bluehearts
◎進入論壇網頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。
|