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>

相關文章

Alibaba Cloud 10 Year Anniversary

With You, We are Shaping a Digital World, 2009-2019

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。