中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

利用JavaScript怎么創建一個樣式表和樣式規則

發布時間:2020-12-18 15:21:10 來源:億速云 閱讀:207 作者:Leah 欄目:開發技術

利用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 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元素,但十分的簡單。

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

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武汉市| 台山市| 安塞县| 鸡泽县| 建昌县| 克什克腾旗| 项城市| 南乐县| 永新县| 沽源县| 伊通| 上思县| 汶上县| 黎城县| 冷水江市| 绥化市| 来安县| 常宁市| 新绛县| 肥东县| 太湖县| 望城县| 松潘县| 东丽区| 红桥区| 和硕县| 易门县| 成都市| 台山市| 惠安县| 彰武县| 霍林郭勒市| 淮安市| 英吉沙县| 张家界市| 莱芜市| 元江| 昭平县| 侯马市| 科技| 年辖:市辖区|