js實現單一html頁面兩套css切換代碼

來源:互聯網
上載者:User

今天研究了一下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下均測試通過,相信大家看完後因該非常明了,利用這個方法我們可以讓瀏覽者自己選擇需要顯示的樣式表,比如年老者可以選擇一個字型較大的樣式表。這裡需要注意的兩點是:
在這個例子中函數名function後面的名字不能為links或者link,如果為links或者link,樣式表將不被改變,具體什麼原因我也不大清楚,可能是javascript的保留字元。
另外如果是改變整個頁面的樣式,你需要在樣式表檔案裡定義body的高度為100%

方法二:
第一步:匯入兩套css檔案 複製代碼 代碼如下:<link rel="stylesheet" type="text/css" title="樣式A" href="css/people1.css" />
<link rel="alternate stylesheet" type="text/css" title="樣式B" href="css/people2.css" />

第二步:寫切換的js函數 複製代碼 代碼如下:<script type="text/javascript">
var title = "樣式A";
function setStyle(){

//只是樣式A 和樣式B切換
if(title=="樣式A"){
title = "樣式B";
}else{
title = "樣式A";
}

var i,links;
//用dom方法擷取所有link元素
links = document.getElementsByTagName("link");
//判斷每個link元素中是否含有style字串 ,用來判斷此link元素為樣式表link ,同時判斷此link是否包含title屬性
for(i=0; links[i]; i++){
if(links[i].getAttribute("rel").indexOf("style") != -1 && links[i].getAttribute("title")){
//把所有link設為disabled
links[i].disabled = true;
//再來判斷title中是否有指定的title字串 有則把當前的link設為可視 即啟用當前的link
if(links[i].getAttribute("title").indexOf(title) != -1){
links[i].disabled = false;
//alert("ok");
}

}
}
}
</script>

第三步:在html標籤中調用切換的js函數 複製代碼 代碼如下:<a href="#" onclick="setStyle();" >1</a>
<a href="#" onclick="setStyle();">2</a>
<a href="#" onclick="setStyle();">3</a>
<a href="#" onclick="setStyle();">4</a>
<a href="#" onclick="setStyle();">5</a>

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.