用JS實現一個頁面多個css樣式實現
更新時間:2008年05月29日 22:53:03 作者:
在Hello,Yang中看見的一篇文章,感覺很有用,轉來這里……
第一步:在連接樣式表的元素里定義一個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%
復制代碼 代碼如下:
<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%
相關文章
用javascript獲取當頁面上鼠標光標位置和觸發(fā)事件的對象的代碼
用 javascript 獲取當頁面上鼠標(光標)位置 和 觸發(fā)事件的對象 的方法2009-12-12event.currentTarget與event.target的區(qū)別介紹
event.currentTarget與event.target的區(qū)別想大家在使用的時候不是很在意,本文以測試代碼來講解它門之間的不同2012-12-12