亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript 動(dòng)態(tài)生成css代碼的兩種方法

 更新時(shí)間:2017年03月17日 10:46:47   作者:源子姍  
這篇文章主要介紹了javascript 動(dòng)態(tài)生成css代碼的兩種方法,有時(shí)候我們需要利用js來(lái)動(dòng)態(tài)生成頁(yè)面上style標(biāo)簽中的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偽類的樣式修改的示例代碼

    本篇文章主要介紹了用js實(shí)現(xiàn)before和after偽類的樣式修改的示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-09-09
  • js獲取form表單所有數(shù)據(jù)的簡(jiǎn)單方法

    js獲取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 刪除單詞的前置空格問(wèn)題記錄

    EventSource是HTML5中的一種新的API,用來(lái)實(shí)現(xiàn)服務(wù)器端向客戶端推送事件,相比于常規(guī)的輪詢方式,EventSource可以實(shí)現(xiàn)更加高效、低延遲的數(shù)據(jù)傳輸,這篇文章主要介紹了解決EventSource 刪除單詞的前置空格問(wèn)題記錄,需要的朋友可以參考下
    2024-03-03
  • javascript引用賦值(地址傳值)用法實(shí)例

    javascript引用賦值(地址傳值)用法實(shí)例

    這篇文章主要介紹了javascript引用賦值(地址傳值)用法,以一個(gè)簡(jiǎn)單實(shí)例分析了javacript引用賦值的原理與用法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • 兩種方法實(shí)現(xiàn)在HTML頁(yè)面加載完畢后運(yùn)行某個(gè)js

    兩種方法實(shí)現(xiàn)在HTML頁(yè)面加載完畢后運(yùn)行某個(gè)js

    這篇文章主要介紹了通過(guò)兩種方法實(shí)現(xiàn)在HTML頁(yè)面加載完畢后運(yùn)行某個(gè)js,需要的朋友可以參考下
    2014-06-06
  • javascript實(shí)現(xiàn)表格排序 編輯 拖拽 縮放

    javascript實(shí)現(xiàn)表格排序 編輯 拖拽 縮放

    這篇文章主要介紹了javascript實(shí)現(xiàn)表格排序 編輯 拖拽 縮放的方法,效果非常不錯(cuò),只是兼容性還有些問(wèn)題,有待優(yōu)化。
    2015-01-01
  • JavaScript中的Window.open()用法示例詳解

    JavaScript中的Window.open()用法示例詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript中Window.open()用法的相關(guān)資料,今天在項(xiàng)目中用到了彈出子窗口,就想到了用JavaScript實(shí)現(xiàn)的兩種方法,其中一個(gè)就是window.open(),需要的朋友可以參考下
    2023-07-07
  • js點(diǎn)擊按鈕實(shí)現(xiàn)圖片排序

    js點(diǎn)擊按鈕實(shí)現(xiàn)圖片排序

    這篇文章主要為大家詳細(xì)介紹了js點(diǎn)擊按鈕實(shí)現(xiàn)圖片排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • js實(shí)現(xiàn)密碼強(qiáng)度檢測(cè)【附示例】

    js實(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-03
  • JS+H5 Canvas實(shí)現(xiàn)時(shí)鐘效果

    JS+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

最新評(píng)論