色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

js 操作css實(shí)現(xiàn)代碼

當(dāng)我們需要的是一條規(guī)則的時(shí)候,總不能在每次dom發(fā)生變化的時(shí)候去執(zhí)行這個(gè)操作,否則也太效率低下了。
好在dom中css rules也是可以修改的。不過不同瀏覽器的對(duì)于css rules的接口描述也不同,其中ie中以類似hash table的方式,而ff以數(shù)組方式。
從可編程性上說,ie的接口描述更討程序員喜歡,不過從邏輯上說,ff顯然更為合理。
我提供了類似于ie的方式對(duì)兩套代碼進(jìn)行簡單包裝,不過ie在dom的css removeRule之后并不能確定同步的把規(guī)則兌現(xiàn)。所以最好用規(guī)則覆蓋的方式而非remove。
需要注意的是,在使用改js函數(shù)的時(shí)候,頁面上至少要有一個(gè)style標(biāo)簽。下面是代碼及示例。
復(fù)制代碼 代碼如下:
<style>
#a:
{
color: blue;
}
</style>
<style>
#a:
{
background: gray;
}
</style>
<script>
function addCSSRule(key,value){
var css = document.styleSheets[document.styleSheets.length-1];
css.cssRules ?
(css.insertRule(key+"{"+value+"}", css.cssRules.length)) :
(css.addRule(key,value)) ;
}
function removeCSSRule(key){
for(var i = 0; i < document.styleSheets.length; i++){
var css = document.styleSheets[i];
css.cssRules ?
(function(){
for(var j = 0; j < css.cssRules.length; j++){
if(css.cssRules[j].selectorText==key){
css.deleteRule(j);
}
}
})() :
(css.removeRule(key)) ;
}
}
</script>
<div id="a">
abc
</div>
<button onclick='addCSSRule("#a","color:red;background:yellow;")'>
add</button>
<button onclick='removeCSSRule("#a")'>
remove</button>

JavaScript技術(shù)js 操作css實(shí)現(xiàn)代碼,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 呈贡县| 银川市| 昭平县| 古田县| 涟源市| 若尔盖县| 礼泉县| 晋江市| 五河县| 五莲县| 弋阳县| 化州市| 原阳县| 建湖县| 铜梁县| 新昌县| 大荔县| 星座| 垦利县| 吴忠市| 石家庄市| 天峨县| 衡阳市| 顺平县| 潮安县| 翼城县| 崇文区| 精河县| 云林县| 德兴市| 营口市| 抚顺县| 贡山| 汾西县| 阳山县| 朝阳市| 屏南县| 增城市| 龙陵县| 嵊州市| 方正县|