国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js 操作css實現代碼

2019-11-21 01:19:33
字體:
來源:轉載
供稿:網友
當我們需要的是一條規則的時候,總不能在每次dom發生變化的時候去執行這個操作,否則也太效率低下了。
好在dom中css rules也是可以修改的。不過不同瀏覽器的對于css rules的接口描述也不同,其中ie中以類似hash table的方式,而ff以數組方式。
從可編程性上說,ie的接口描述更討程序員喜歡,不過從邏輯上說,ff顯然更為合理。
我提供了類似于ie的方式對兩套代碼進行簡單包裝,不過ie在dom的css removeRule之后并不能確定同步的把規則兌現。所以最好用規則覆蓋的方式而非remove。
需要注意的是,在使用改js函數的時候,頁面上至少要有一個style標簽。下面是代碼及示例。
復制代碼 代碼如下:

<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>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 龙南县| 涞水县| 开江县| 遂溪县| 工布江达县| 京山县| 南阳市| 秦皇岛市| 桂林市| 乌审旗| 济宁市| 张家界市| 广平县| 营口市| 东丽区| 迁西县| 崇信县| 楚雄市| 萝北县| 莎车县| 卢龙县| 扎兰屯市| 阜城县| 会泽县| 泸溪县| 安顺市| 丹凤县| 犍为县| 东乡| 清徐县| 深水埗区| 博野县| 河池市| 类乌齐县| 阿拉尔市| 定日县| 喀喇| 灌云县| 崇明县| 中牟县| 奉新县|