如何用JavaScript實(shí)現(xiàn)動(dòng)態(tài)修改CSS樣式表
看過(guò)我寫(xiě)的《用JavaScript動(dòng)態(tài)建立或增加CSS樣式表的實(shí)現(xiàn)方法》之后,你就很容易想明白如何修改CSS樣式表了。
正好今天在論壇碰到一位朋友問(wèn)這樣的一個(gè)問(wèn)題:
<style> .ls{width=120px;} </style> <script> //在這里加一句來(lái)改變.ls中width的值,如何寫(xiě) </script>
有的朋友回答:“如果使用.ls的對(duì)象很多的話,用JS確實(shí)不方便, jquery方便,$(".ls").width(200);這樣就行”。
他是想用JQ的類(lèi)選擇器.ls選擇所有使用這個(gè)樣式的對(duì)象,對(duì)它們逐個(gè)進(jìn)行調(diào)整,而非更改CSS樣式表,所以會(huì)有“對(duì)象很多”的顧慮。
但問(wèn)題是,這只是改了那些對(duì)象的具體表現(xiàn)樣式,而并非改了.LS的設(shè)置。如果再出現(xiàn)一個(gè)使用.LS風(fēng)格的元素,它還是老樣子,你還需要對(duì)這個(gè)元素再去調(diào)整,治標(biāo)不治本。而且這種方式也決定了不可能簡(jiǎn)單地通過(guò)一句話就實(shí)現(xiàn)。
這樣想的人還不少,而如果你看了《用JavaScript動(dòng)態(tài)建立或增加CSS樣式表的實(shí)現(xiàn)方法》這篇文章之后,相信你很容易就想到如何用一句話來(lái)解決這個(gè)問(wèn)題,既簡(jiǎn)潔高效(瀏覽器會(huì)自動(dòng)重新設(shè)置所有應(yīng)用這個(gè)樣式的元素),而且真正的修改了樣式設(shè)置,新增的使用這個(gè)樣式的元素將自動(dòng)應(yīng)用被修改過(guò)的設(shè)置。于是,你已經(jīng)學(xué)到了和很多人區(qū)分開(kāi)來(lái)的更高階的知識(shí)。下面我把方法具體再說(shuō)一下:
由于上面的例子,不容易看出效果,我下面另外寫(xiě)了個(gè)例子,通過(guò)顏色的改變,比較容易看到效果:
<STYLE> .theforever {width:50px;color:red;} #theforever {width:150px;color:silver;} </STYLE> <div class="theforever">這里應(yīng)該是紅色的,但它會(huì)被下面的JS通過(guò)改變CSS樣式設(shè)置而變成黃色</div> <div id="theforever">這里應(yīng)該是銀灰色的,的確這個(gè)不會(huì)發(fā)生變化,只作為對(duì)比</div> <script> document.styleSheets[0].cssText=document.styleSheets[0].cssText.replace(/red/g,"yellow"); //一句,不就OK了? </script>
上面的例子,針對(duì)的不是某個(gè)特定的樣式名稱,而是泛泛的顏色(如果你直接挪到含有更為復(fù)雜的CSS頁(yè)面里,其中有不表示顏色的RED字樣,這還會(huì)導(dǎo)致錯(cuò)誤。我對(duì)不動(dòng)腦子的代碼拿來(lái)主義者一向極其反感,不作過(guò)多指示),但如果想要針對(duì)特定的樣式名稱進(jìn)行更改,同樣很容易:
從上面,可以看出document.styleSheets[0].cssText就是整個(gè)<STYLE></STYLE>內(nèi)部的內(nèi)容,相當(dāng)于一個(gè)字串變量,所以假如針對(duì).LS要改變它的設(shè)置,只需要把“.ls{width=120px;}”作為 replace 要替換的部分,把“.ls{width=555px;}”作為替換目標(biāo),這樣就行了。
以上這篇如何用JavaScript實(shí)現(xiàn)動(dòng)態(tài)修改CSS樣式表就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
js實(shí)現(xiàn)axios限制請(qǐng)求隊(duì)列
本文主要介紹了js實(shí)現(xiàn)axios限制請(qǐng)求隊(duì)列,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07用JavaScript實(shí)現(xiàn)仿Windows關(guān)機(jī)效果
用JavaScript實(shí)現(xiàn)仿Windows關(guān)機(jī)效果...2007-03-03JavaScript中常用的簡(jiǎn)潔高級(jí)技巧總結(jié)
這篇文章主要給大家總結(jié)介紹了關(guān)于JavaScript中常用的簡(jiǎn)潔高級(jí)技巧,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用Javascript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03Express框架Router?Route?Layer對(duì)象使用示例詳解
這篇文章主要為大家介紹了Express框架Router?Route?Layer對(duì)象使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03layui: layer.open加載窗體時(shí)出現(xiàn)遮罩層的解決方法
今天小編就為大家分享一篇layui: layer.open加載窗體時(shí)出現(xiàn)遮罩層的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09JavaScript中Array的實(shí)用操作技巧分享
最近在調(diào)試JSP頁(yè)面時(shí)頻繁與ajax打交道,在復(fù)雜場(chǎng)景下,ajax傳參數(shù)就需要對(duì)大量參數(shù)進(jìn)行處理。這時(shí)我才發(fā)現(xiàn),熟練Array的處理真的會(huì)使開(kāi)發(fā)輕松不少!!下面就給大家分享下JavaScript中Array的實(shí)用操作技巧,有需要的可以參考借鑒。2016-09-09js中對(duì)函數(shù)設(shè)置默認(rèn)參數(shù)值的3種方法
這篇文章主要介紹了js中對(duì)函數(shù)設(shè)置默認(rèn)參數(shù)值的3種方法嗎,3種方法都具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-10-10JavaScript實(shí)現(xiàn)計(jì)算字符串中出現(xiàn)次數(shù)最多的字符和出現(xiàn)的次數(shù)
這篇文章主要介紹了JavaScript實(shí)現(xiàn)計(jì)算字符串中出現(xiàn)次數(shù)最多的字符和出現(xiàn)的次數(shù),本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-03-03js文件中直接alert()中文出來(lái)的是亂碼的解決方法
下面小編就為大家?guī)?lái)一篇js文件中直接alert()中文出來(lái)的是亂碼的解決方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11js實(shí)現(xiàn)計(jì)算器和計(jì)時(shí)器功能
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)計(jì)算器和計(jì)時(shí)器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07