首页 web前端 js教程 向当前style sheet中插入一个新的style实现方法_javascript技巧

向当前style sheet中插入一个新的style实现方法_javascript技巧

May 16, 2016 pm 05:38 PM
style 样式

很少会插入一个新的style rule,今天为了临时解决页面样式问题,需要更新很多页面的一些样式,这些页面都引用了一个公共的js,为了方便,直接在这个公共的js里面向style sheet插入新的style rule。

先看代码:

复制代码 代码如下:

/**
* 在文档中添加样式表规则(可能是更好的做法,
* 动态更改类,因此样式信息可以保留在
* 真正的样式表中(并避免向 DOM 添加额外的元素) ))
* 请注意,声明和规则需要一个数组,因为 ECMAScript
* 无法提供可预测的对象迭代顺序,并且 CSS 是
* 顺序相关的(即,它是级联的);那些不需要
* 级联规则的人可以构建一个更加访问者友好的基于对象的 API。
* @param {Array} decls 接受 JSON 编码声明的数组
* @example
addStylesheetRules([
['h2', // 还接受第二个参数作为数组的数组而是
['color', 'red'],
['background-color', 'green', true] // 'true' !重要规则
],
['. myClass',
['背景颜色', '黄色']
]
]);
*/
function addStylesheetRules (decls) {
var style = document.createElement('style');
document.getElementsByTagName('head')[0].appendChild(style);
if (!window.createPopup) { /* For Safari */
style.appendChild(document.createTextNode(''));
}
var s = document.styleSheets[document.styleSheets.length - 1];
for (var i=0, dl = decls.length; i < dl; i ) {
var j = 1, decl = decls[i], selector = decl[0], rulesStr = '';
if (Object.prototype.toString.call(decl[1][0]) === '[object Array]') {
decl = decl[1];
j = 0;
}
for (var rl=decl.length; j < rl; j ) {
var rule = decl[j];
rulesStr = rule[0] ':' rule[1] (rule[2] ? ' !important' : '') ';n';
}
if (s.insertRule) {
s.insertRule(selector '{' rulesStr '}', s.cssRules.length);
}
else { /* IE */
s.addRule(selector, rulesStr, -1);
}
}
}

复制代码 代码如下:

addStylesheetRules(["div.content", ["color": "#000"], ["border-width","1px"], ["border-style", "solid"]])

执行后当前document的head标签内,多了一个style
复制代码 代码如下:


知道怎么调用了吧,每次调用都会插入一个新的style,所以最好调用一次,插入多个rule
复制代码 代码如下:

addStylesheetRules(
[selector, [attr, value], …],
[selector, [attr, value], …]
);

主要用到两个方法
标准方法:stylesheet.insertRule(rule, index)
rule:被插入的rule,如 div.content{color:#000}
index: 插入顺序,先后顺序会影响样式的。从0开始
firefox、chrome、opera、safri、ie从ie9开始也支持这个方法
ie的stylesheet.addRule (selector, styleDef [, positionIndex]);
selector:如div.content
styleDef:如color:#000
positionIndex:默认-1,插入到末尾
ie、safari、chrome支持这个方法
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

macOS:如何更改桌面小部件的颜色 macOS:如何更改桌面小部件的颜色 Oct 07, 2023 am 08:17 AM

macOS:如何更改桌面小部件的颜色

element.style怎么修改 element.style怎么修改 Nov 24, 2023 am 11:15 AM

element.style怎么修改

WordPress网页错位现象解决攻略 WordPress网页错位现象解决攻略 Mar 05, 2024 pm 01:12 PM

WordPress网页错位现象解决攻略

react 怎么动态修改style react 怎么动态修改style Dec 28, 2022 am 10:44 AM

react 怎么动态修改style

Vue3 style中新增的特性有哪些及怎么用 Vue3 style中新增的特性有哪些及怎么用 May 14, 2023 pm 10:52 PM

Vue3 style中新增的特性有哪些及怎么用

CSS网页背景图设计:创建各种背景图样式和效果 CSS网页背景图设计:创建各种背景图样式和效果 Nov 18, 2023 am 08:38 AM

CSS网页背景图设计:创建各种背景图样式和效果

Vue报错:无法正确使用v-bind绑定class和style,怎样解决? Vue报错:无法正确使用v-bind绑定class和style,怎样解决? Aug 26, 2023 pm 10:58 PM

Vue报错:无法正确使用v-bind绑定class和style,怎样解决?

使用:nth-last-child(2)伪类选择器选择倒数第二个子元素的样式 使用:nth-last-child(2)伪类选择器选择倒数第二个子元素的样式 Nov 20, 2023 am 11:22 AM

使用:nth-last-child(2)伪类选择器选择倒数第二个子元素的样式

See all articles