通過js訪問style屬性 alert(document.getElementById("main").style.backg " /> 亚洲日本欧美天堂在线,日本高清天码一区在线播放,MMM日本兽交

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Javascript 訪問樣式表實現代碼

再記錄一下 Javascript訪問樣式表
Javascript可以訪問網頁中元素的style屬性,例如:
<div id="main" style="background-color:red"></div>

通過js訪問style屬性
alert(document.getElementById("main").style.backgroundColor);

通過js改變style屬性
document.getElementById("main").style.backgroundColor="blue";

以上代碼是我們所熟悉的,但通常我們用樣式表來控制元素的外觀屬性,例如:

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]

此時如果我們再使用 alert(document.getElementById("main").style.backgroundColor);

則只能獲得一個空值,所以只能通過js去訪問樣式表了.
document.styleSheets可以獲得樣式表的集合,因為瀏覽器之間有很大不同,訪問樣式表的單獨規則也不同.DOM為每一個樣式表指定一個cssRules集合,Mozilla和Safari正確實現了這個標準,不過可惜IE中定義這個集合為rules,因此可以使用以下代碼來獲得正確的對象:
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;

這樣就可以獲得不同瀏覽器的CSS集合了.
通過以下JS代碼來獲得樣式表中的樣式:
復制代碼 代碼如下:
function GetCSS()
{
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;
alert(oCssRules[0].style.backgroundColor);
}

styleSheets[0]表示第一個樣式表引用,oCssRules[0]表示第一個樣式規則(即#main{}的內容),通過style屬性來訪問具體的規則.
同理,更改該樣式表規則代碼如下:
復制代碼 代碼如下:
function SetCSS()
{
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;
oCssRules[0].style.backgroundColor="red";
oCssRules[0].style.marginLeft="20px";
oCssRules[0].style.marginTop="20px";
}


但是需要注意的是,因為很多元素有可能關聯同一個樣式表,所以改變時需要慎重.
除了元素的style對象和css規則外,每個元素還有一個最終樣式,最終樣式用來告訴我們元素最后是如何顯示在屏幕上的,也就是style和css重合計算后的樣式.IE和DOM有兩種方式來訪問此樣式,IE中通過currentStyle屬性,DOM中使用getComputedStyle()方法.
JS獲得最終樣式的方法如下:
復制代碼 代碼如下:
function GetFinalCSS()
{
var oDiv=document.getElementById("main");
//訪問style屬性
alert(oDiv.style.backgroundColor);
//IE方法
alert(oDiv.currentStyle.backgroundColor);
//DOM方法,第二個參數為偽元素,如:hover,first-leeter之類
//alert(document.defaultView.getComputeStyle(oDiv,null).backgroundColor);
}

我經常使用currentStyle來獲得樣式,省去了訪問樣式表的麻煩
需要注意的是currentStyle是只讀屬性,不能夠對其賦值,因為其是多種樣式綜合計算后的樣式規則,這點并不難理解.
對于getComputedStyle方法,可以通過document.defaultView來調用(IE和Safari不支持此方法).所以,當使用getComputedStyle方法時,最好在多個瀏覽器上進行測試.

JavaScript技術Javascript 訪問樣式表實現代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲最大在线视频 | 麻豆无人区乱码 | 天天澡夜夜澡人人澡 | 穿着丝袜被男生强行啪啪 | 国产MD视频一区二区三区 | 超碰公开在线caopon | 久久伊人在 | 亚洲乱码在线卡一卡二卡新区 | 秋霞伦理高清视频在线 | 国产不卡无码高清视频 | 99国产精品久久人妻无码 | adc免费观看 | 99热最新网站 | 色欲国产麻豆一精品一AV一免费 | xxx性欧美在线观看 xxx性欧美在线 | 国产精品丰满人妻AV麻豆 | 久久re亚洲在线视频 | 1819sextub欧美中国 | 污到湿的爽文免费阅读 | 桃花色影院 | 日日夜夜天天操 | 黄色三级视频在线观看 | 最新国产av.在线视频 | 伊人久久精品午夜 | 天天狠狠弄夜夜狠狠躁·太爽了 | 国产一级毛片在线 | 超污视频带污疼免费视频 | 久久久97人妻无码精品蜜桃 | 手机伊在人线香蕉2 | 久久精品国产99欧美精品亚洲 | 超碰免费视频部落格 | 秀婷程仪公欲息肉婷在线观看 | 国产精品高潮AV久久无码 | 在线免费观看视频a | 99日影院在线播放 | 久久成人午夜电影mp4 | 99久视频只有精品2019 | 亚洲 国产 日韩 欧美 在线 | 午夜理论电影在线观看亚洲 | 亚洲中文在线精品国产 | 国精产品一区一区三区有 |