中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

使用JavaScript創建新樣式表和新樣式規則
來源:易賢網 閱讀:1102 次 日期:2016-08-17 14:45:17
溫馨提示:易賢網小編為您整理了“使用JavaScript創建新樣式表和新樣式規則”,方便廣大網友查閱!

這篇文章主要介紹了使用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 stylesheet

console.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 type

console.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.)

以上就是本文的全部內容,希望對大家的學習有所幫助

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
久久精品欧洲| 亚洲视频一区二区在线观看| 亚洲影视在线播放| 国产精品免费观看在线| 亚洲欧美日韩电影| 国产日韩欧美不卡在线| 久久精品九九| 日韩亚洲欧美在线观看| 国产欧美日韩一区二区三区在线 | 国产三级欧美三级日产三级99| 亚洲精品免费在线观看| 久久午夜激情| 一区二区免费看| 亚洲国产精品传媒在线观看 | 亚洲乱码视频| 亚洲精品在线免费| 欧美wwwwww| 999在线观看精品免费不卡网站| 国产日韩欧美精品一区| 先锋亚洲精品| 99精品免费视频| 久久青草欧美一区二区三区| 亚洲精品一区二区三区在线观看 | 欧美日韩天天操| 亚洲欧美日韩直播| 亚洲欧洲一区二区天堂久久| 国产麻豆综合| 欧美国产精品va在线观看| 亚洲人被黑人高潮完整版| 欧美新色视频| 亚洲欧美乱综合| 亚洲国产精品嫩草影院| 久久亚洲视频| 亚洲网友自拍| 狠狠综合久久| 国产精品久久国产愉拍| 午夜精品久久久久| 国产精品国产精品| 欧美专区在线观看| 国产一区日韩一区| 老司机精品视频一区二区三区| 91久久精品视频| 欧美日韩欧美一区二区| 午夜精品久久久久| 亚洲精品资源| 韩国在线视频一区| 欧美久久精品午夜青青大伊人| 亚洲欧美日韩视频二区| 亚洲精品在线观| 欧美日韩视频在线观看一区二区三区| 国产日韩久久| 欧美色视频一区| 嫩草国产精品入口| 久久久久亚洲综合| 久久精品国产精品亚洲精品| 性久久久久久| 在线亚洲激情| 一本色道久久99精品综合| 亚洲毛片在线看| 亚洲精品国产精品国自产观看浪潮| 一区二区三区在线高清| 国产日韩精品一区二区三区 | 亚洲黄一区二区三区| 国内精品一区二区| 国产精品乱码妇女bbbb| 欧美日韩视频在线| 欧美视频免费在线观看| 欧美理论视频| 欧美日韩久久| 欧美日韩国产一区二区| 久久免费视频观看| 欧美一区二区在线看| 亚洲欧美综合精品久久成人| 亚洲摸下面视频| 亚洲在线免费视频| 午夜精品国产| 亚洲主播在线观看| 亚洲欧美日韩国产成人| 性娇小13――14欧美| 校园激情久久| 久久国产精品72免费观看| 欧美在线三级| 久久亚洲影院| 久久久999成人| 久久精品国产亚洲高清剧情介绍| 久久精品青青大伊人av| 久久亚洲一区| 欧美精品 日韩| 蜜臀av在线播放一区二区三区 | 国产亚洲成av人在线观看导航 | 99在线精品视频| 亚洲高清三级视频| 影音先锋日韩有码| 亚洲啪啪91| 亚洲精品日韩精品| 99精品热6080yy久久| 亚洲网站在线看| 亚洲男女自偷自拍| 性久久久久久久久| 欧美主播一区二区三区| 免费欧美高清视频| 欧美大片一区二区| 国产精品成人一区二区艾草| 国产欧美91| 一区视频在线| 99精品视频免费| 亚洲欧美日韩综合| 久久久久久国产精品mv| 欧美国产免费| 国产精品福利影院| 激情五月婷婷综合| 欧美成人国产一区二区| 欧美91福利在线观看| 欧美三级网页| 国产精品视频一二| 在线电影国产精品| 亚洲一区二区欧美| 久久精品综合一区| 欧美日韩四区| 国产亚洲va综合人人澡精品| 亚洲精品免费在线观看| 午夜激情综合网| 欧美亚洲在线观看| 欧美日韩国产小视频| 国产精品网站在线| 亚洲黄色av一区| 亚洲欧美一区二区三区在线| 久久亚洲欧洲| 国产精品免费一区豆花| 国产一区二区视频在线观看| 亚洲日本aⅴ片在线观看香蕉| 亚洲天堂偷拍| 久久亚洲精品网站| 国产精品伦理| 亚洲黄色在线| 亚洲视频在线看| 久久精品国亚洲| 欧美亚州韩日在线看免费版国语版| 激情久久一区| 一区二区三区精品国产| 欧美日韩专区| 亚洲欧洲精品一区二区精品久久久| 午夜在线不卡| 国产精品二区在线| 亚洲福利在线看| 国产精品一区二区久久久久| 亚洲精品男同| 久久精品亚洲一区二区| 国产精品视频福利| 欧美视频一区二区三区| 国产精品乱码一区二三区小蝌蚪| 亚洲欧洲精品一区二区| 先锋影音网一区二区| 欧美日韩第一页| 亚洲国产精品成人va在线观看| 欧美一区2区三区4区公司二百| 欧美日韩激情小视频| 亚洲二区精品| 久久国产精品亚洲va麻豆| 国产精品久久久久久久久久久久| 亚洲国产综合视频在线观看| 久久久蜜桃一区二区人| 国产欧美一区在线| 亚洲一区二区四区| 国产精品久久久久久亚洲调教 | 国产九区一区在线| 亚洲午夜一区二区| 欧美国产三级| 国产在线不卡精品| 午夜精品一区二区三区在线视| 欧美精品一区二区三区蜜桃 | 久久黄色影院| 国产精品视频一区二区高潮| 欧美精品日本| 日韩视频在线你懂得| 欧美成人精品不卡视频在线观看| 亚洲成人影音| 亚洲一区二区三区在线看| 国产精品va在线播放| 一本色道久久综合亚洲精品高清 | 欧美亚洲一区二区三区| 欧美日韩在线亚洲一区蜜芽 | 亚洲视频专区在线| 欧美日本免费| 一区二区电影免费在线观看| 欧美黄色aa电影| 亚洲人成网站色ww在线| 欧美极品影院| av成人激情| 国产精品久久9| 亚洲制服av| 国产欧美日韩| 久久精品二区三区| 激情久久久久久| 欧美v日韩v国产v| 亚洲精品免费一区二区三区| 免费在线成人| 亚洲特色特黄| 国产精品日韩一区| 久久免费视频网|