1. <tt id="5hhch"><source id="5hhch"></source></tt>
    1. <xmp id="5hhch"></xmp>

  2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

    <rp id="5hhch"></rp>
        <dfn id="5hhch"></dfn>

      1. JavaScript創(chuàng)建對象方法最新

        時間:2020-10-16 19:45:53 JavaScript 我要投稿

        JavaScript創(chuàng)建對象方法2017最新

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

          捕獲樣式表

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

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

          返回:

          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屬性——如果你不小心,當(dāng)想往屏幕顯示使用的樣式表里做修改操作時,你也許會錯誤的修改了用于打印(print)時使用的樣式表。CSSStyleSheet對象里有各種屬性信息,需要時你可以從中獲取。

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

          返回結(jié)果:

          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

          */

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

          創(chuàng)建一個新的樣式表

          大多數(shù)時候,最好的方法是創(chuàng)建一個新的STYLE元素,動態(tài)的往里面添加規(guī)則。非常簡單:

          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 補(bǔ)丁

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

          // Add the <style> element to the page

          document.head.appendChild(style);

          return style.sheet;})();

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

          添加樣式規(guī)則 – 標(biāo)準(zhǔn)的addRule方法

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

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

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

          你會發(fā)現(xiàn),這種技術(shù)的優(yōu)勢在于,它可以動態(tài)的往頁面上添加樣式規(guī)則,并應(yīng)用它們;你不必對每個元素進(jìn)行操作,瀏覽器會自動應(yīng)用這些規(guī)則。高效吧!

          新增樣式規(guī)則

          CSSStyleSheet對象里還有一個insertRule方法,但在早期的IE里是沒有這個方法的。insertRule方法把a(bǔ)ddRule方法的前兩個參數(shù)混合到了一起:

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

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

          安全的應(yīng)用樣式規(guī)則

          因?yàn)椴⒉皇撬械臑g覽器都支持insertRule,最好我們做一些封裝來確保代碼的有效執(zhí)行。下面就是一個很簡單的封裝方法:

          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");

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

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

          有兩個方法可以為特定的媒體查詢增加樣式規(guī)則。第一種是通過標(biāo)準(zhǔn)的insertRule方法:

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

          因?yàn)槔鲜降腎E不支持insertRule,我們可以使用另外一種方法,就是創(chuàng)建一個STYLE元素,賦予它正確的media屬性,然后往里面添加新的樣式規(guī)則。這種方式會增加額外的STYLE元素,但十分的簡單。

          我認(rèn)為動態(tài)的往樣式表里添加樣式規(guī)則是一種十分高效而且簡單的技術(shù)。記住在你的下一個應(yīng)用里試一下這種技術(shù),它會省了你很多功夫。

        【JavaScript創(chuàng)建對象方法2017最新】相關(guān)文章:

        1.JavaScript中創(chuàng)建字典對象(dictionary)的實(shí)例

        2.javascript數(shù)據(jù)創(chuàng)建方法參考

        3.關(guān)于Javascript對象屬性方法匯總

        4.javascript中String對象的slice()方法

        5.使用ajax操作JavaScript對象的方法

        6.理解Javascript對象

        7.JavaScript 中有關(guān)時間對象有哪些方法

        8.javascript設(shè)置創(chuàng)建動態(tài)表格的方法

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码

        1. <tt id="5hhch"><source id="5hhch"></source></tt>
          1. <xmp id="5hhch"></xmp>

        2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

          <rp id="5hhch"></rp>
              <dfn id="5hhch"></dfn>