欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2017年03月17日 10:46:47   作者:源子姍  
這篇文章主要介紹了javascript 動態(tài)生成css代碼的兩種方法,有時候我們需要利用js來動態(tài)生成頁面上style標簽中的css代碼,下面就給大家介紹兩種方法,需要的朋友可以參考下

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

有時候我們需要利用js來動態(tài)生成頁面上style標簽中的css代碼,方法很直接,就是直接創(chuàng)建一個style元素,然后設(shè)置style元素里面的css代碼,最后把它插入到head元素中。但有些兼容性問題我們需要解決。首先在符合w3c標準的瀏覽器中我們只需要把要插入的css代碼作為一個文本節(jié)點插入到style元素中即可,而在IE中則需要利用style元素的styleSheet.cssText來解決。還需要注意的就是在有些版本IE中一個頁面上style標簽數(shù)量是有限制的,如果超過了會報錯,需要考慮這點。

方法1:

給<style id="css">標簽添加一個id名,在<script>標簽中寫

var oCss=document.getElementById("css");

oCss.innerHTML+="#box{width:200px;}";

這樣就可以加上樣式了。

方法2:

有時候我們需要利用js來動態(tài)生成頁面上style標簽中的css代碼,方法很直接,就是直接創(chuàng)建一個style元素,然后設(shè)置style元素里面的css代碼,最后把它插入到head元素中。但有些兼容性問題我們需要解決。首先在符合w3c標準的瀏覽器中我們只需要把要插入的css代碼作為一個文本節(jié)點插入到style元素中即可,而在IE中則需要利用style元素的styleSheet.cssText來解決。還需要注意的就是在有些版本IE中一個頁面上style標簽數(shù)量是有限制的,如果超過了會報錯,需要考慮這點。

下面直接放上代碼,看注釋說明。

function addCSS(cssText){
  var style = document.createElement('style'), //創(chuàng)建一個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ù)量超過限制而發(fā)生錯誤
        style.styleSheet.cssText = cssText;
      }catch(e){

      }
    }
    //如果當前styleSheet還不能用,則放到異步中則行
    if(style.styleSheet.disabled){
      setTimeout(func,10);
    }else{
      func();
    }
  }else{ //w3c
    //w3c瀏覽器中只要創(chuàng)建文本節(jié)點插入到style元素中就行了
    var textNode = document.createTextNode(cssText);
    style.appendChild(textNode);
  }
  head.appendChild(style); //把創(chuàng)建的style元素插入到head中  
}

//使用
addCSS('#demo{ height: 30px; background:#f00;}');

當然這只是一個最基本的演示方法,實際運用中還需進行完善,比如把每次生成的css代碼都插入到一個style元素中,這樣在IE中就不會發(fā)生stylesheet數(shù)量超出限制的錯誤了。

總結(jié):以上方法可以解決很多問題,有什么不懂的找我!

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • 用js實現(xiàn)before和after偽類的樣式修改的示例代碼

    用js實現(xiàn)before和after偽類的樣式修改的示例代碼

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

    js獲取form表單所有數(shù)據(jù)的簡單方法

    下面小編就為大家?guī)硪黄猨s獲取form表單所有數(shù)據(jù)的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • 解決EventSource 刪除單詞的前置空格問題記錄

    解決EventSource 刪除單詞的前置空格問題記錄

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

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

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

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

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

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

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

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

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

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

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

    js實現(xiàn)密碼強度檢測【附示例】

    下面小編就為大家?guī)硪黄猨s實現(xiàn)密碼強度檢測【附示例】。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-03-03
  • JS+H5 Canvas實現(xiàn)時鐘效果

    JS+H5 Canvas實現(xiàn)時鐘效果

    這篇文章主要為大家詳細介紹了JS+H5 Canvas實現(xiàn)時鐘效果,利用JavaScript和Canvas實現(xiàn)簡單時鐘效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07

最新評論