如何用JavaScript實現(xiàn)動態(tài)修改CSS樣式表
看過我寫的《用JavaScript動態(tài)建立或增加CSS樣式表的實現(xiàn)方法》之后,你就很容易想明白如何修改CSS樣式表了。
正好今天在論壇碰到一位朋友問這樣的一個問題:
<style>
.ls{width=120px;}
</style>
<script>
//在這里加一句來改變.ls中width的值,如何寫
</script>
有的朋友回答:“如果使用.ls的對象很多的話,用JS確實不方便, jquery方便,$(".ls").width(200);這樣就行”。
他是想用JQ的類選擇器.ls選擇所有使用這個樣式的對象,對它們逐個進行調(diào)整,而非更改CSS樣式表,所以會有“對象很多”的顧慮。
但問題是,這只是改了那些對象的具體表現(xiàn)樣式,而并非改了.LS的設(shè)置。如果再出現(xiàn)一個使用.LS風(fēng)格的元素,它還是老樣子,你還需要對這個元素再去調(diào)整,治標(biāo)不治本。而且這種方式也決定了不可能簡單地通過一句話就實現(xiàn)。
這樣想的人還不少,而如果你看了《用JavaScript動態(tài)建立或增加CSS樣式表的實現(xiàn)方法》這篇文章之后,相信你很容易就想到如何用一句話來解決這個問題,既簡潔高效(瀏覽器會自動重新設(shè)置所有應(yīng)用這個樣式的元素),而且真正的修改了樣式設(shè)置,新增的使用這個樣式的元素將自動應(yīng)用被修改過的設(shè)置。于是,你已經(jīng)學(xué)到了和很多人區(qū)分開來的更高階的知識。下面我把方法具體再說一下:
由于上面的例子,不容易看出效果,我下面另外寫了個例子,通過顏色的改變,比較容易看到效果:
<STYLE>
.theforever {width:50px;color:red;}
#theforever {width:150px;color:silver;}
</STYLE>
<div class="theforever">這里應(yīng)該是紅色的,但它會被下面的JS通過改變CSS樣式設(shè)置而變成黃色</div>
<div id="theforever">這里應(yīng)該是銀灰色的,的確這個不會發(fā)生變化,只作為對比</div>
<script>
document.styleSheets[0].cssText=document.styleSheets[0].cssText.replace(/red/g,"yellow");
//一句,不就OK了?
</script>
上面的例子,針對的不是某個特定的樣式名稱,而是泛泛的顏色(如果你直接挪到含有更為復(fù)雜的CSS頁面里,其中有不表示顏色的RED字樣,這還會導(dǎo)致錯誤。我對不動腦子的代碼拿來主義者一向極其反感,不作過多指示),但如果想要針對特定的樣式名稱進行更改,同樣很容易:
從上面,可以看出document.styleSheets[0].cssText就是整個<STYLE></STYLE>內(nèi)部的內(nèi)容,相當(dāng)于一個字串變量,所以假如針對.LS要改變它的設(shè)置,只需要把“.ls{width=120px;}”作為 replace 要替換的部分,把“.ls{width=555px;}”作為替換目標(biāo),這樣就行了。
以上這篇如何用JavaScript實現(xiàn)動態(tài)修改CSS樣式表就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
一文詳解JavaScript中的replace()函數(shù)
replace方法的語法是stringObj.replace(rgExp, replaceText),其中stringObj是字符串(string),下面這篇文章主要給大家介紹了關(guān)于JavaScript中replace()函數(shù)的相關(guān)資料,需要的朋友可以參考下2023-01-01
javascript模擬實現(xiàn)C# String.format函數(shù)功能代碼
這篇文章主要介紹了javascript模擬實現(xiàn)C# String.format函數(shù)功能,相信大家可以用的到2013-11-11
基于JS代碼實現(xiàn)簡單易用的倒計時 x 天 x 時 x 分 x 秒效果
這篇文章主要介紹了基于JS代碼實現(xiàn)簡單易用的倒計時 x 天 x 時 x 分 x 秒效果,需要的朋友可以參考下2017-07-07
在JavaScript中終止forEach循環(huán)的三種方式
如何終止forEach循環(huán)這個問題估計會難倒一部分同學(xué),甚至?xí)腥朔磫?forEach循環(huán)在JavaScript中能終止嗎?本文小編給大家介紹了三種方式可以終止forEach循環(huán),需要的朋友可以參考下2023-11-11
淺談JavaScript 執(zhí)行環(huán)境、作用域及垃圾回收
下面小編就為大家?guī)硪黄獪\談JavaScript:執(zhí)行環(huán)境、作用域及垃圾回收。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05
利用js給datalist或select動態(tài)添加option選項的方法
下面小編就為大家分享一篇利用js給datalist或select動態(tài)添加option選項的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01

