首頁 web前端 js教程 javascript控制css樣式所有樣式程式碼實例匯總

javascript控制css樣式所有樣式程式碼實例匯總

Jul 19, 2017 pm 04:43 PM
css javascript

記錄JS控制CSS所使用的方法. 

使用javascript更改某個css class的屬性...

<style type="text/css"> 
.orig { 
display: none; 
} 
</style>
登入後複製

你想要改變把他的display屬性由none改為inline。
解決方法: 在IE裡:

document.styleSheets[0].rules[0].style.display = "inline";
登入後複製

在firefox裡:

document.styleSheets[0].cssRules[0].style.display = "inline";
登入後複製

討論: 可以做一個函數來搜尋特定名字的style物件:

function getstyle(sname) { 
for (var i=0;i<document.styleSheets.length;i++) { 
var rules; 
if (document.styleSheets[i].cssRules) { 
rules = document.styleSheets[i].cssRules; 
} else { 
rules = document.styleSheets[i].rules; 
} 
for (var j=0;j<rules.length;j++) { 
if (rules[j].selectorText == sname) { 
//selectorText 属性的作用是对一个选择的地址进行替换.意思应该是获取RULES[J]的CLASSNAME.有说错的地方欢迎指正 
return rules[j].style; 
} 
} 
} 
}
登入後複製

然後只要:

getstyle(".orig").display = "inline";
登入後複製

就可以了。
------------------ 注意document.styleSheets[0].rules[0].style 這個styleSheets[0]陣列的下標是代表本頁的第N個CSS樣式表,它的下級rules[0]的數組下標表示的則是這個樣式表中的第N個樣式,例如:

<style type="text/css"> 
.s{display="none";} 
.w{display="none";} 
</style>
登入後複製

修改S則: document.styleSheets [0].rules[0].style.display='inline';
修改W則:document.styleSheets[0].rules[1].style.display = 'inline';
注意:CSS且HTML結合的方式必須為的時候以上方法可行,如@IMPORT 則不行. 


下面記錄JS訪問CSS中的樣式:
用javascript獲取和設定style
DOM標準引入了覆蓋樣式表的概念,當我們用document.getElementById(" id").style.backgroundColor 取得樣式時取得的只是id中style屬性中設定的背景色,如果id中的style屬性中沒有設定background-color那麼就會回傳空,也就是說如果id用class屬性引用了一個外部樣式表,在這個外部樣式表中設置的背景色,那麼不好意思document.getElementById("id").style.backgroundColor 這種寫法不好使,如果要獲取外部樣式表中的設置,需要用到window物件的getComputedStyle()方法,程式碼這樣寫

window.getComputedStyle(id,null).backgroundColor
登入後複製

但是相容問題又來了,這麼寫在firefox中好使,但在IE中不好使
兩者相容的方式寫成

window.getComputedStyle?window.getComputedStyle(id,null).backgroundColor:id.currentStyle["backgroundColor"];
登入後複製

如果是取得背景色,這種方法在firefox和IE中的返回值還是不一樣的,IE中是返回"#ffff99"樣子的,而firefox中返回"rgb (238, 44, 34) "
值得注意的是:window.getComputedStyle(id,null)這種方式不能設定樣式,只能取得,要設定還得寫成類似這樣id.style.background="# EE2C21";
在IE中CURRENTSTYLE只能以唯讀方式取得樣式.




以上是javascript控制css樣式所有樣式程式碼實例匯總的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

vue中placeholder是什麼意思 vue中placeholder是什麼意思 May 07, 2024 am 09:57 AM

vue中placeholder是什麼意思

js中span是什麼意思 js中span是什麼意思 May 06, 2024 am 11:42 AM

js中span是什麼意思

js中rem是什麼意思 js中rem是什麼意思 May 06, 2024 am 11:30 AM

js中rem是什麼意思

vue中引入圖片的方法 vue中引入圖片的方法 May 02, 2024 pm 10:48 PM

vue中引入圖片的方法

span標籤的作用是什麼 span標籤的作用是什麼 Apr 30, 2024 pm 01:54 PM

span標籤的作用是什麼

js中prompt怎麼換行 js中prompt怎麼換行 May 01, 2024 am 06:24 AM

js中prompt怎麼換行

瀏覽器插件是什麼語言寫的 瀏覽器插件是什麼語言寫的 May 08, 2024 pm 09:36 PM

瀏覽器插件是什麼語言寫的

js中什麼是節點 js中什麼是節點 May 07, 2024 pm 09:06 PM

js中什麼是節點

See all articles