<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • JavaScript創建對象方法最新

    時間:2024-08-26 19:11:08 JavaScript 我要投稿
    • 相關推薦

    JavaScript創建對象方法2017最新

      JavaScript開發者們與原型鏈的關系總是若即若離,糾纏不清。在JavaScript中“創建對象”是一個復雜的話題。這門語言提供了很多種創建對象的方式,不論新手還是老手都可能對此感到無所適從,不知道應該選擇哪一種。不過,盡管創建對象的方法很多,看上去語法差異也很大,但實際上它們的相似性可能比你所以為的要多。本文將帶領你踏上一段梳理對象創建方法的旅程,為你揭示不同方法之間的依賴與遞進關系。

      捕獲樣式表

      你的頁面上可能引用了不只一個的樣式文件,你可以選擇其中的一個。如果你指定了某個,你可以在HTML頁面中的LINK 和 STYLE標簽上加入ID來進行區別,獲取CSSStyleSheet對象,它存放在document.styleSheets對象里。

      var sheets = document.styleSheets; // 返回一個StyleSheetList數組/*

      返回:

      StyleSheetList {0: CSSStyleSheet, 1: CSSStyleSheet, 2: CSSStyleSheet, 3: CSSStyleSheet, 4: CSSStyleSheet, 5: CSSStyleSheet, 6: CSSStyleSheet, 7: CSSStyleSheet, 8: CSSStyleSheet, 9: CSSStyleSheet, 10: CSSStyleSheet, 11: CSSStyleSheet, 12: CSSStyleSheet, 13: CSSStyleSheet, 14: CSSStyleSheet, 15: CSSStyleSheet, length: 16, item: function}

      */// 找到你想要修改的樣式表var sheet = document.styleSheets[0];

      一個重要的需要注意的事情是樣式表的media屬性——如果你不小心,當想往屏幕顯示使用的樣式表里做修改操作時,你也許會錯誤的修改了用于打印(print)時使用的樣式表。CSSStyleSheet對象里有各種屬性信息,需要時你可以從中獲取。

      // Get info about the first stylesheetconsole.log(document.styleSheets[0]);/*

      返回結果:

      CSSStyleSheet

      cssRules: CSSRuleList

      disabled: false

      href: "http://davidwalsh.name/somesheet.css"

      media: MediaList

      ownerNode: link

      ownerRule: null

      parentStyleSheet: null

      rules: CSSRuleList

      title: null

      type: "text/css"

      */// Get the media typeconsole.log(document.styleSheets[0].media.mediaText)/*

      Returns:

      "all" or "print" or whichever media is used for this stylesheet

      */

      有很多方法都可以讓你捕獲一個樣式表,往里面添加新樣式規則。

      創建一個新的樣式表

      大多數時候,最好的方法是創建一個新的STYLE元素,動態的往里面添加規則。非常簡單:

      var sheet = (function() {

      // Create the <style> tag

      var style = document.createElement("style");

      // 如果你愿意的話,可以添加media屬性 (或 media query)

      // style.setAttribute("media", "screen")

      // style.setAttribute("media", "@media only screen and (max-width : 1024px)")

      // WebKit 補丁

      style.appendChild(document.createTextNode(""));

      // Add the <style> element to the page

      document.head.appendChild(style);

      return style.sheet;})();

      不幸的是,WebKit類型的瀏覽器需求做一點點小修改,才能讓上面的代碼正確的運行,但不管怎樣,我們獲得了想要的sheet。

      添加樣式規則 – 標準的addRule方法

      CSSStyleSheet對象里有一個addRule方法,它可以接受3個參數:選擇器、樣式規則的CSS代碼和一個整數,這個整數用來指示樣式表的位置(相對于同樣的選擇器):

      sheet.addRule("#myList li", "float: left; background: red !important;", 1);

      位置缺省值為-1,表示放在最后。為了進行額外的控制,或偷懶的寫法,你可以在規則里添加!important來消除位置引起的問題。調用addRule會返回-1——它什么都不表示。

      你會發現,這種技術的優勢在于,它可以動態的往頁面上添加樣式規則,并應用它們;你不必對每個元素進行操作,瀏覽器會自動應用這些規則。高效吧!

      新增樣式規則

      CSSStyleSheet對象里還有一個insertRule方法,但在早期的IE里是沒有這個方法的。insertRule方法把addRule方法的前兩個參數混合到了一起:

      sheet.insertRule("header { float: left; opacity: 0.8; }", 1);

      這個方法看起來很丑陋,但無疑也是非常有用的。

      安全的應用樣式規則

      因為并不是所有的瀏覽器都支持insertRule,最好我們做一些封裝來確保代碼的有效執行。下面就是一個很簡單的封裝方法:

      function addCSSRule(sheet, selector, rules, index) {

      if(sheet.insertRule) {

      sheet.insertRule(selector + "{" + rules + "}", index);

      }

      else {

      sheet.addRule(selector, rules, index);

      }}// Use it!addCSSRule(document.styleSheets[0], "header", "float: left");

      這個方法可以應對各種情況。如果你想把這個方法里的代碼單獨拿出來使用,最好用try{}catch(e){}把它們包起來。

      為媒體查詢(Media Queries)增加樣式規則

      有兩個方法可以為特定的媒體查詢增加樣式規則。第一種是通過標準的insertRule方法:

      sheet.insertRule("@media only screen and (max-width : 1140px) { header { display: none; } }");

      因為老式的IE不支持insertRule,我們可以使用另外一種方法,就是創建一個STYLE元素,賦予它正確的media屬性,然后往里面添加新的樣式規則。這種方式會增加額外的STYLE元素,但十分的簡單。

      我認為動態的往樣式表里添加樣式規則是一種十分高效而且簡單的技術。記住在你的下一個應用里試一下這種技術,它會省了你很多功夫。

    【JavaScript創建對象方法最新】相關文章:

    javascript數據創建方法參考07-30

    關于Javascript對象屬性方法匯總08-24

    javascript中String對象的slice()方法09-27

    使用ajax操作JavaScript對象的方法09-28

    JavaScript中創建字典對象(dictionary)的實例07-31

    javascript設置創建動態表格的方法09-19

    理解Javascript對象08-22

    JavaScript常用對象的方法和屬性小結講解08-22

    關于javascript對象之內置和對象Math的使用方法10-08

    Javascript中arguments對象的詳解和使用方法08-20

    主站蜘蛛池模板: 久热这里只精品99re8久| 一区二区精品在线| 99国产精品国产免费观看| 夜夜爽一区二区三区精品| 久久亚洲精品视频| 无码人妻精品一区二区三区东京热 | 国产精品久久久久久久久鸭| 欧美亚洲综合免费精品高清在线观看| 国产亚洲婷婷香蕉久久精品| 亚洲中文久久精品无码ww16| 国产欧美精品一区二区三区四区| 98视频精品全部国产| 婷婷国产成人精品视频| 久久久久久国产精品无码下载 | 国产精品原创巨作av女教师| 亚洲欧美精品午睡沙发| 国产视频精品免费视频| 欧美成人精品一级高清片| 国产精品v片在线观看不卡 | 国产欧美久久久精品| 精品无码AV无码免费专区| 亚洲精品永久在线观看| 久久九九久精品国产免费直播| 99久re热视频这里只有精品6| 999久久久免费精品国产| 精品人妻久久久久久888| 亚洲精品高清国产一线久久| 久久露脸国产精品| 国产乱人伦偷精品视频| 国产福利电影一区二区三区,欧美国产成人精品一 | 国产精品内射久久久久欢欢| 国产短视频精品一区二区三区| 日产欧美国产日韩精品| 中文字幕日本精品一区二区三区| 免费精品精品国产欧美在线欧美高清免费一级在线 | 97久久精品人妻人人搡人人玩| 久久亚洲欧美国产精品 | 久久亚洲中文字幕精品一区四| 国产精品丝袜久久久久久不卡| 99热热久久这里只有精品68 | 青青久久精品国产免费看|