Javascript 訪問樣式表實現(xiàn)代碼
更新時間:2009年08月20日 02:08:05 作者:
Javascript訪問樣式表--又一篇好文章
再記錄一下 Javascript訪問樣式表
Javascript可以訪問網(wǎng)頁中元素的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需再刷新一下頁面才能執(zhí)行]
此時如果我們再使用 alert(document.getElementById("main").style.backgroundColor);
則只能獲得一個空值,所以只能通過js去訪問樣式表了.
document.styleSheets可以獲得樣式表的集合,因為瀏覽器之間有很大不同,訪問樣式表的單獨規(guī)則也不同.DOM為每一個樣式表指定一個cssRules集合,Mozilla和Safari正確實現(xiàn)了這個標準,不過可惜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]表示第一個樣式規(guī)則(即#main{}的內(nèi)容),通過style屬性來訪問具體的規(guī)則.
同理,更改該樣式表規(guī)則代碼如下:
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";
}
但是需要注意的是,因為很多元素有可能關(guān)聯(lián)同一個樣式表,所以改變時需要慎重.
除了元素的style對象和css規(guī)則外,每個元素還有一個最終樣式,最終樣式用來告訴我們元素最后是如何顯示在屏幕上的,也就是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方法,第二個參數(shù)為偽元素,如:hover,first-leeter之類
//alert(document.defaultView.getComputeStyle(oDiv,null).backgroundColor);
}
我經(jīng)常使用currentStyle來獲得樣式,省去了訪問樣式表的麻煩
需要注意的是currentStyle是只讀屬性,不能夠?qū)ζ滟x值,因為其是多種樣式綜合計算后的樣式規(guī)則,這點并不難理解.
對于getComputedStyle方法,可以通過document.defaultView來調(diào)用(IE和Safari不支持此方法).所以,當使用getComputedStyle方法時,最好在多個瀏覽器上進行測試.
Javascript可以訪問網(wǎng)頁中元素的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需再刷新一下頁面才能執(zhí)行]
此時如果我們再使用 alert(document.getElementById("main").style.backgroundColor);
則只能獲得一個空值,所以只能通過js去訪問樣式表了.
document.styleSheets可以獲得樣式表的集合,因為瀏覽器之間有很大不同,訪問樣式表的單獨規(guī)則也不同.DOM為每一個樣式表指定一個cssRules集合,Mozilla和Safari正確實現(xiàn)了這個標準,不過可惜IE中定義這個集合為rules,因此可以使用以下代碼來獲得正確的對象:
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;
這樣就可以獲得不同瀏覽器的CSS集合了.
通過以下JS代碼來獲得樣式表中的樣式:
復(fù)制代碼 代碼如下:
function GetCSS()
{
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;
alert(oCssRules[0].style.backgroundColor);
}
styleSheets[0]表示第一個樣式表引用,oCssRules[0]表示第一個樣式規(guī)則(即#main{}的內(nèi)容),通過style屬性來訪問具體的規(guī)則.
同理,更改該樣式表規(guī)則代碼如下:
復(fù)制代碼 代碼如下:
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";
}
但是需要注意的是,因為很多元素有可能關(guān)聯(lián)同一個樣式表,所以改變時需要慎重.
除了元素的style對象和css規(guī)則外,每個元素還有一個最終樣式,最終樣式用來告訴我們元素最后是如何顯示在屏幕上的,也就是style和css重合計算后的樣式.IE和DOM有兩種方式來訪問此樣式,IE中通過currentStyle屬性,DOM中使用getComputedStyle()方法.
JS獲得最終樣式的方法如下:
復(fù)制代碼 代碼如下:
function GetFinalCSS()
{
var oDiv=document.getElementById("main");
//訪問style屬性
alert(oDiv.style.backgroundColor);
//IE方法
alert(oDiv.currentStyle.backgroundColor);
//DOM方法,第二個參數(shù)為偽元素,如:hover,first-leeter之類
//alert(document.defaultView.getComputeStyle(oDiv,null).backgroundColor);
}
我經(jīng)常使用currentStyle來獲得樣式,省去了訪問樣式表的麻煩
需要注意的是currentStyle是只讀屬性,不能夠?qū)ζ滟x值,因為其是多種樣式綜合計算后的樣式規(guī)則,這點并不難理解.
對于getComputedStyle方法,可以通過document.defaultView來調(diào)用(IE和Safari不支持此方法).所以,當使用getComputedStyle方法時,最好在多個瀏覽器上進行測試.
您可能感興趣的文章:
- JavaScript修改css樣式style
- JS 控制CSS樣式表
- 再談javascript 動態(tài)添加樣式規(guī)則 W3C校檢
- JavaScript CSS修改學習第三章 修改樣式表
- javascript 動態(tài)修改樣式和層疊樣式表代碼
- javascript判斷ie瀏覽器6/7版本加載不同樣式表的實現(xiàn)代碼
- JS函數(shù)實現(xiàn)動態(tài)添加CSS樣式表文件
- JS修改css樣式style淺談
- JavaScript實現(xiàn)動態(tài)創(chuàng)建CSS樣式規(guī)則方案
- 使用JavaScript創(chuàng)建新樣式表和新樣式規(guī)則
相關(guān)文章
php main 與 iframe 相互通訊類(js+php同域/跨域)
這篇文章主要介紹了php main 與 iframe 相互通訊類(js+php同域/跨域),需要的朋友可以參考下2017-09-09超級簡單實現(xiàn)JavaScript MVC 樣式框架
本文給大家分享的是一則翻譯過來的,由國外友人寫的如何簡單有效的實現(xiàn)javascript MVC樣式框架,算是一個MVC的入門教程,希望大家能夠喜歡。2015-03-03JavaScript控制listbox列表框的項目上下移動的方法
這篇文章主要介紹了JavaScript控制listbox列表框的項目上下移動的方法,實例分析了javascript操作listbox列表框的技巧,非常具有實用價值,需要的朋友可以參考下2015-03-03在JavaScript中獲取請求的URL參數(shù)[正則]
在ASP.NET后臺代碼中,對于這樣的URL請求地址:http://www.abc.com?id=001,我們可以通過Request.QueryString["id"]的方法很容易的獲取到URL中請求的參數(shù)的值,但是要在前臺js代碼中獲取請求的參數(shù)的值,應(yīng)該怎么做呢?2010-12-12通過JS判斷聯(lián)網(wǎng)類型和連接狀態(tài)的實現(xiàn)代碼
這篇文章主要介紹了通過JS判斷聯(lián)網(wǎng)類型和連接狀態(tài)的實現(xiàn)代碼,需要的朋友可以參考下2015-04-04JavaScript實現(xiàn)找出字符串中第一個不重復(fù)的字符
這篇文章主要介紹了JavaScript實現(xiàn)找出字符串中第一個不重復(fù)的字符的方法,需要的朋友可以參考下2014-09-09擴展IE中一些不兼容的方法如contains、startWith等等
擴展IE中一些不兼容的方法如contains方法、startWith方法等等,下面是具體的實現(xiàn)代碼,喜歡的朋友可以參考下2014-01-01