javascript 動(dòng)態(tài)生成css代碼的兩種方法
javascript 動(dòng)態(tài)生成css代碼的兩種方法
有時(shí)候我們需要利用js來(lái)動(dòng)態(tài)生成頁(yè)面上style標(biāo)簽中的css代碼,方法很直接,就是直接創(chuàng)建一個(gè)style元素,然后設(shè)置style元素里面的css代碼,最后把它插入到head元素中。但有些兼容性問(wèn)題我們需要解決。首先在符合w3c標(biāo)準(zhǔn)的瀏覽器中我們只需要把要插入的css代碼作為一個(gè)文本節(jié)點(diǎn)插入到style元素中即可,而在IE中則需要利用style元素的styleSheet.cssText來(lái)解決。還需要注意的就是在有些版本IE中一個(gè)頁(yè)面上style標(biāo)簽數(shù)量是有限制的,如果超過(guò)了會(huì)報(bào)錯(cuò),需要考慮這點(diǎn)。
方法1:
給<style id="css">標(biāo)簽添加一個(gè)id名,在<script>標(biāo)簽中寫(xiě)
var oCss=document.getElementById("css"); oCss.innerHTML+="#box{width:200px;}";
這樣就可以加上樣式了。
方法2:
有時(shí)候我們需要利用js來(lái)動(dòng)態(tài)生成頁(yè)面上style標(biāo)簽中的css代碼,方法很直接,就是直接創(chuàng)建一個(gè)style元素,然后設(shè)置style元素里面的css代碼,最后把它插入到head元素中。但有些兼容性問(wèn)題我們需要解決。首先在符合w3c標(biāo)準(zhǔn)的瀏覽器中我們只需要把要插入的css代碼作為一個(gè)文本節(jié)點(diǎn)插入到style元素中即可,而在IE中則需要利用style元素的styleSheet.cssText來(lái)解決。還需要注意的就是在有些版本IE中一個(gè)頁(yè)面上style標(biāo)簽數(shù)量是有限制的,如果超過(guò)了會(huì)報(bào)錯(cuò),需要考慮這點(diǎn)。
下面直接放上代碼,看注釋說(shuō)明。
function addCSS(cssText){ var style = document.createElement('style'), //創(chuàng)建一個(gè)style元素 head = document.head || document.getElementsByTagName('head')[0]; //獲取head元素 style.type = 'text/css'; //這里必須顯示設(shè)置style元素的type屬性為text/css,否則在ie中不起作用 if(style.styleSheet){ //IE var func = function(){ try{ //防止IE中stylesheet數(shù)量超過(guò)限制而發(fā)生錯(cuò)誤 style.styleSheet.cssText = cssText; }catch(e){ } } //如果當(dāng)前styleSheet還不能用,則放到異步中則行 if(style.styleSheet.disabled){ setTimeout(func,10); }else{ func(); } }else{ //w3c //w3c瀏覽器中只要?jiǎng)?chuàng)建文本節(jié)點(diǎn)插入到style元素中就行了 var textNode = document.createTextNode(cssText); style.appendChild(textNode); } head.appendChild(style); //把創(chuàng)建的style元素插入到head中 } //使用 addCSS('#demo{ height: 30px; background:#f00;}');
當(dāng)然這只是一個(gè)最基本的演示方法,實(shí)際運(yùn)用中還需進(jìn)行完善,比如把每次生成的css代碼都插入到一個(gè)style元素中,這樣在IE中就不會(huì)發(fā)生stylesheet數(shù)量超出限制的錯(cuò)誤了。
總結(jié):以上方法可以解決很多問(wèn)題,有什么不懂的找我!
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
用js實(shí)現(xiàn)before和after偽類的樣式修改的示例代碼
本篇文章主要介紹了用js實(shí)現(xiàn)before和after偽類的樣式修改的示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09js獲取form表單所有數(shù)據(jù)的簡(jiǎn)單方法
下面小編就為大家?guī)?lái)一篇js獲取form表單所有數(shù)據(jù)的簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08解決EventSource 刪除單詞的前置空格問(wèn)題記錄
EventSource是HTML5中的一種新的API,用來(lái)實(shí)現(xiàn)服務(wù)器端向客戶端推送事件,相比于常規(guī)的輪詢方式,EventSource可以實(shí)現(xiàn)更加高效、低延遲的數(shù)據(jù)傳輸,這篇文章主要介紹了解決EventSource 刪除單詞的前置空格問(wèn)題記錄,需要的朋友可以參考下2024-03-03兩種方法實(shí)現(xiàn)在HTML頁(yè)面加載完畢后運(yùn)行某個(gè)js
這篇文章主要介紹了通過(guò)兩種方法實(shí)現(xiàn)在HTML頁(yè)面加載完畢后運(yùn)行某個(gè)js,需要的朋友可以參考下2014-06-06javascript實(shí)現(xiàn)表格排序 編輯 拖拽 縮放
這篇文章主要介紹了javascript實(shí)現(xiàn)表格排序 編輯 拖拽 縮放的方法,效果非常不錯(cuò),只是兼容性還有些問(wèn)題,有待優(yōu)化。2015-01-01JavaScript中的Window.open()用法示例詳解
這篇文章主要給大家介紹了關(guān)于JavaScript中Window.open()用法的相關(guān)資料,今天在項(xiàng)目中用到了彈出子窗口,就想到了用JavaScript實(shí)現(xiàn)的兩種方法,其中一個(gè)就是window.open(),需要的朋友可以參考下2023-07-07js實(shí)現(xiàn)密碼強(qiáng)度檢測(cè)【附示例】
下面小編就為大家?guī)?lái)一篇js實(shí)現(xiàn)密碼強(qiáng)度檢測(cè)【附示例】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-03-03JS+H5 Canvas實(shí)現(xiàn)時(shí)鐘效果
這篇文章主要為大家詳細(xì)介紹了JS+H5 Canvas實(shí)現(xiàn)時(shí)鐘效果,利用JavaScript和Canvas實(shí)現(xiàn)簡(jiǎn)單時(shí)鐘效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07