JavaScript訪問(wèn)CSS屬性的幾種方式介紹
JavaScript訪問(wèn)CSS屬性的方式總體說(shuō)來(lái)有兩種:“通過(guò)元素訪問(wèn)”、“直接訪問(wèn)樣式表”。另外訪問(wèn)樣式的時(shí)候有一個(gè)不可忽略的問(wèn)題——運(yùn)行時(shí)樣式。
1.通過(guò)元素訪問(wèn)
既然是要通過(guò)元素訪問(wèn)樣式表,那么就應(yīng)該先確定是哪個(gè)元素。這是DOM的內(nèi)容,在此先不多說(shuō)。獲取引用之后就可以通過(guò) “引用.style.要訪問(wèn)的屬性” ,來(lái)訪問(wèn)某個(gè)屬性。舉個(gè)例子,看如下代碼。
<pre name="code" class="html"><pre name="code" class="html"><!DOCTYPE html> <html> <head> <meta charset="utf-8"> <style> #a{ height:100px; width:100px; background-color:red; } </style> </head> <body> <div id="a"></div> </body> </html>
當(dāng)我們想要獲取#a的背景色的時(shí)候就可以 document.getElementById("a").style.backgroundColor;這樣就完成了訪問(wèn),之后是要返回還是更改屬性值那就隨你便了。
2.直接訪問(wèn)樣式表
直接訪問(wèn)樣式表總的來(lái)說(shuō)就是“先找到相應(yīng)的樣式塊,然后在該樣式塊里找相應(yīng)的樣式規(guī)則,最后在該樣式規(guī)則里找相應(yīng)的樣式”。
先說(shuō)什么是樣式塊。在代碼中,CSS代碼會(huì)存在于<style></style>標(biāo)簽之間或<link>之中,一個(gè)<style></style>或<link>就是一個(gè)樣式塊。在代碼中可能從上到下依次排列著多個(gè)代碼塊,我們可以像訪問(wèn)數(shù)組元素一樣訪問(wèn)樣式塊。例如我們要訪問(wèn)樣式塊中的第一個(gè),就可以document.styleSheets[0]
然后說(shuō)什么是樣式規(guī)則。先看如下代碼
<pre name="code" class="html"><!DOCTYPE html> <html> <head> <meta charset="utf-8"> <style> #a{ height:100px; width:100px; background-color:red; } #b{ height:100px; width:100px; background-color:blue; } </style> </head> <body> <div id="a"></div> <div id="b"></div> </body> </html>
代碼中分別規(guī)定了#a和#b的樣式,#a的樣式的集合或#b的集合就是一個(gè)樣式規(guī)則。在這個(gè)樣式塊中,對(duì)#a的是第一個(gè)樣式規(guī)則,對(duì)#b的是第二個(gè)樣式規(guī)則。我們同樣可以像訪問(wèn)數(shù)組元素一樣訪問(wèn)樣式規(guī)則。例如我們要訪問(wèn)#b樣式規(guī)則,就可以document.styleSheets[0].cssRules[1] 當(dāng)然你可以選擇這么寫(xiě)document.styleSheet[0].rules[1]但這種寫(xiě)法不被Firefox支持。
然后我們就可以訪問(wèn)相應(yīng)的樣式了。例如我們要把#b的背景色改成綠色,就可以document.styleSheets[0].cssRules[1].style.backgroundColor="green";
3.運(yùn)行時(shí)樣式
看如下代碼:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <style> #a{ height:100px; width:100px; color:red; } #b{ height:100px; width:100px; } </style> </head> <body> <div id="a"> <div id="b">觀察字體顏色</div> </div> </body> </html>
當(dāng)我們運(yùn)行alert(document.getElementById("b").style.color);的時(shí)候發(fā)現(xiàn)彈窗上什么都沒(méi)輸出,但頁(yè)面的字體顏色明明是紅色,為啥呢?這是因?yàn)槊總€(gè)元素的style對(duì)象屬性并不是即時(shí)更新的。當(dāng)我們要彈窗上輸出紅色的時(shí)候就要用運(yùn)行時(shí)樣式。window.getComputedStyle(document.getElementById("b"),null).color這樣就可以訪問(wèn)到“紅色”。訪問(wèn)運(yùn)行時(shí)樣式也有另外一種寫(xiě)法document.getElementById("b").currentStyle.color 但這種寫(xiě)法只有IE支持。
相關(guān)文章
Javascript的數(shù)組與字典用法與遍歷對(duì)象的屬性技巧
Javascript 的數(shù)組Array,既是一個(gè)數(shù)組,也是一個(gè)字典(Dictionary)。先舉例看看數(shù)組的用法2012-11-11微信小程序?qū)崿F(xiàn)手勢(shì)滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)手勢(shì)滑動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08讓GoogleCode的SVN下的HTML文件在FireFox下正常顯示.
GoogleCode可以作為免費(fèi)的穩(wěn)定的靜態(tài)資源空間來(lái)使用,比如JQuery的文檔就在上面2009-05-05JavaScript數(shù)據(jù)結(jié)構(gòu)鏈表知識(shí)詳解
存儲(chǔ)有序的元素集合,但不同于數(shù)組,鏈表中的元素在內(nèi)存中不是連續(xù)放置的。每個(gè)元素由一個(gè)存儲(chǔ)元素本身的節(jié)點(diǎn)和一個(gè)指向下一個(gè)元素的引用(也稱指針或鏈接)組成。下面通過(guò)本文給大家詳細(xì)介紹下,需要的朋友參考下2016-11-11禁止彈窗中蒙層底部頁(yè)面跟隨滾動(dòng)的幾種方法
我們大家在做彈出層的時(shí)候,必不可少的一個(gè)元素就是蒙層,也就是遮罩層,當(dāng)彈出層滾動(dòng)的時(shí)候,蒙層底部的頁(yè)面一般是要求固定不動(dòng)的,所以這篇文章就來(lái)給大家介紹了如何禁止彈窗中蒙層底部頁(yè)面跟隨滾動(dòng)的幾種方法,需要的朋友可以參考下。2017-12-12JavaScript中Number對(duì)象的toFixed() 方法詳解
下面小編就為大家?guī)?lái)一篇JavaScript中Number對(duì)象的toFixed() 方法詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09js 判斷一個(gè)數(shù)字是不是2的n次方冪的實(shí)例
下面小編就為大家分享一篇js 判斷一個(gè)數(shù)字是不是2的n次方冪的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助2017-11-11