亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

使用JavaScript創建新樣式表和新樣式規則

2024-05-04 23:47:14
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了使用JavaScript創建新樣式表和新樣式規則的相關資料,需要的朋友可以參考下
 

如今的這個年代,流行在Web頁面上使用了大量的JavaScript,我們需要尋找各種方式來優化它們,使它們更快。我們使用事件委托來讓事件監聽器更有效率,使用降頻技術來限定某些方法的使用次數,使用各種JavaScript加載器來動態加載我們需要的資源,等等。另外一種讓頁面更高效、更敏捷的方法是動態的添加或移除樣式表里的樣式,而不需要去查詢DOM元素,對每個元素做樣式調整。下面我們就來看看如何使用這種技術!

捕獲樣式表

你的頁面上可能引用了不只一個的樣式文件,你可以選擇其中的一個。如果你指定了某個,你可以在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元素,但十分的簡單。

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

(英文:Add Rules to Stylesheets with JavaScript.)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。



注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人免费高清完整版在线观看| 98视频在线噜噜噜国产| 秋霞成人午夜鲁丝一区二区三区| 91av免费观看91av精品在线| 日韩最新中文字幕电影免费看| 尤物99国产成人精品视频| 久久精品国产91精品亚洲| 一区二区欧美日韩视频| 最近免费中文字幕视频2019| 久久精品国产亚洲一区二区| 欧美精品久久久久久久久久| 亚洲资源在线看| 日韩高清不卡av| 国产精品88a∨| 欧美第一黄色网| 日本韩国在线不卡| 精品亚洲国产视频| 国产亚洲一区精品| 91wwwcom在线观看| 欧美大码xxxx| 福利一区福利二区微拍刺激| 中文字幕亚洲一区二区三区五十路| 中文字幕日韩精品有码视频| 中文字幕亚洲欧美日韩2019| 午夜精品在线观看| 欧美性猛交xxxx免费看久久久| 欧美电影免费播放| 在线看日韩欧美| 懂色av影视一区二区三区| 91午夜在线播放| 国产色综合天天综合网| 国产一区欧美二区三区| 欧美自拍视频在线| 91精品国产乱码久久久久久蜜臀| 久久久国产精品x99av| 亚洲最大福利网| 久久久伊人日本| 欧美一性一乱一交一视频| 美女黄色丝袜一区| 高清亚洲成在人网站天堂| 成人国产在线激情| 日本精品免费观看| 亚洲欧美在线一区二区| 国产亚洲精品久久久优势| 日韩在线观看免费网站| 日本精品视频在线| www国产91| 国产91成人video| 久久久久亚洲精品| 亚洲欧美日韩爽爽影院| 色多多国产成人永久免费网站| 中文字幕自拍vr一区二区三区| 国产精品自产拍在线观| 午夜免费久久久久| 亚洲欧美日韩精品久久| 国产精品免费电影| 92看片淫黄大片看国产片| 日本亚洲欧美三级| 色综合久久88色综合天天看泰| 亚洲精品美女久久久| 综合网日日天干夜夜久久| 亚洲国产精品人人爽夜夜爽| 亚洲国产欧美一区| 国产成人综合一区二区三区| 精品一区二区三区三区| 超碰91人人草人人干| 欧美一区二三区| 77777少妇光屁股久久一区| 九九久久久久久久久激情| 国产91色在线|| 美女精品视频一区| 91成人福利在线| 久久久久女教师免费一区| 亚洲精品视频免费在线观看| 亚洲精品小视频在线观看| 精品国产鲁一鲁一区二区张丽| 亚洲国产精品久久久| 国产99视频在线观看| 欧美激情精品久久久久久大尺度| 亚洲女人天堂色在线7777| 国产精品第一区| 欧美激情视频一区| 日韩在线不卡视频| 亚洲欧美日韩成人| 欧美日韩国产精品一区二区三区四区| 成人深夜直播免费观看| 亚洲男人第一网站| 亚洲男女自偷自拍图片另类| 国产欧美一区二区三区久久人妖| 国产精品亚洲美女av网站| 黑人精品xxx一区一二区| 日韩中文在线中文网在线观看| 亚洲aⅴ男人的天堂在线观看| 日韩精品在线观看一区| 亚洲成人黄色在线| 国内精品伊人久久| 91av在线精品| 成人免费视频97| 九九视频这里只有精品| 91精品国产自产在线老师啪| 国产成人综合精品在线| 欧美日韩在线观看视频小说| 欧美激情在线观看视频| 国产精品久久久久久久久影视| 国产成人中文字幕| 国产一区二区三区在线视频| 97视频人免费观看| 国产日韩欧美日韩大片| 久久视频在线免费观看| 欧美激情第99页| 97免费视频在线| 国产成人综合久久| 精品中文字幕久久久久久| 成人激情黄色网| 日韩精品在线第一页| 欧美大片免费观看在线观看网站推荐| 日韩欧美国产免费播放| 欧美极品在线播放| 3344国产精品免费看| 欧美日韩亚洲一区二区三区| 国产视频精品va久久久久久| 久久精品中文字幕| 亚洲图片欧美午夜| 91高清免费在线观看| 国产剧情日韩欧美| 97视频色精品| 国产精品久久久久久久久免费看| 久久精品国产精品亚洲| 九九精品视频在线观看| 久久久久成人网| 亚洲成人久久久久| 青青久久av北条麻妃海外网| 中文字幕日韩专区| 国内精品免费午夜毛片| 亚洲免费小视频| 成人福利视频在线观看| 国产欧美日韩丝袜精品一区| 另类视频在线观看| 日韩av片永久免费网站| 亚洲欧洲在线免费| 国产亚洲精品va在线观看| 91福利视频网| 国产精品久久久一区| 中文字幕在线日韩| 中文字幕最新精品| 亚洲美女精品成人在线视频| 久久亚洲精品中文字幕冲田杏梨| 久久人人爽人人爽人人片亚洲| 欧美猛交ⅹxxx乱大交视频| 久久免费观看视频| 亚洲一区二区三区在线视频| 国产精品第七十二页| 中文字幕国产精品久久| 亚洲色图日韩av| 亚洲a∨日韩av高清在线观看| 欧美成人免费在线视频| 亚洲国产一区二区三区在线观看| 国产91色在线播放| 国内精品400部情侣激情| 一区二区三区精品99久久| 欧美成人免费在线视频| 亚洲精品久久久久久下一站| 欧美成人免费全部| 欧美日韩电影在线观看|