JS读写CSS样式的方法汇总


Posted in Javascript onAugust 16, 2016

为了日后方便查询,本人翻阅了一些资料总结了以下方法,仅限原生JS,如有不对的地方欢迎指出!只求大家看完觉得有学到点什么就OK了!

一、可以通过DOM节点对象的style对象(即CSSStyleDeclaration对象)来读写文档元素的CSS样式
如:var elm = document.getElementById('test');
      elm.style.color = 'black';

二、通过Element对象的getAttribute()、setAttribute()、removeAttribute()直接读写style属性
 如:elm.setAttribute('style','color:red;line-height:30px');

三、通过CSSStyleDeclaration对象的cssText属性和setProperty()、removeProperty等方法
如:

elm.style.cssText ='color:red;line-height:30px';
elm.style.removeProperty('color');
elm.style.setProperty('color', 'green', 'important');
elm.style.cssText = ''; //快速清空该规则的所有声明

每一条CSS规则的样式声明部分(大括号内部的部分),都是一个CSSStyleDeclaration对象,它的属性和方法:
属性:
1.cssText:当前规则的所有样式声明文本。该属性可读写,即可用来设置当前规则。
2.length:当前规则包含多少条声明。
3.parentRule:包含当前规则的那条规则,同CSSRule接口的parentRule属性。
方法:
1.getPropertyPriority()方法返回指定声明的优先级,如果有的话,就是“important”,否则就是空字符串;
2.getPropertyValue方法返回指定声明的值;
3.item(index)方法返回指定位置的属性名,一般用[index]语法更直接;
4.removeProperty方法用于删除一条CSS属性,返回被删除的值;
5.setProperty方法用于设置指定的CSS属性,没有返回值;

四、利用document.styleSheets属性,返回当前页面的所有StyleSheet对象(即所有样式表),它是一个只读的类数组对象,它的元素是CSSStyleSheet对象(继承自StyleSheet对象),该对象的属性方法如下:
属性:
1.cssRules类数组对象,元素是样式表中CSS规则CSSStyleRule对象;IE9以下为rules;
2.disabled属性用于打开或关闭一张样式表,值为true或disabled;
3.ownerNode属性返回StyleSheet对象所在的DOM节点,通常是<link>或<style>。对于那些由其他样式表引用的样式表,该属性为null;
4.因为CSS的@import命令允许在样式表中加载其他样式表,就有了parentStyleSheet属性,它返回包括了当前样式表的那张样式表。如果当前样式表是顶层样式表,则该属性返回null;
5.type属性返回StyleSheet对象的type值,通常是text/css;
6.title属性返回StyleSheet对象的title值;
7.href属性是只读属性,返回StyleSheet对象连接的样式表地址。对于内嵌的style节点,该属性等于null;
8.media属性表示这个样式表是用于屏幕(screen),还是用于打印(print),或两者都适用(all),该属性只读,默认值是screen;
方法:deleteRule()从样式表中删除一条规则,insertRule()向样式表中插入一条新规则,IE9以下为addRule()、removeRule();
如:

document.styleSheets[0].insertRule('#test:hover{color: white;}',0);
 document.styleSheets[0].deleteRule(0); //删除样式表中的第一条规则
 document.styleSheets[0].cssRules[1].selectorText; //返回选择器字符串
 document.styleSheets[0].cssRules[1].cssText; //返回规则字符串,含选择器

 document.styleSheets[0].cssRules[1].style.border;
 document.styleSheets[0].cssRules[1].style.cssText; //返回当前规则的所有样式声明字符串

五、用window对象的getComputedStyle方法,第一个参数是Element对象,第二个参数可以是null、空字符串、伪元素字符串,该方法返回一个只读的表示计算样式的CSSStyleDeclaration对象,它代表了实际应用在指定元素上的最终样式信息,即各种CSS规则叠加后的结果; 

如:var color = window.getComputedStyle(elm, ':before').color;
       var color = window.getComputedStyle(elm, ':before').getPropertyValue('color');
       或:var color = window.getComputedStyle(elm, null).color;

表示计算样式的CSSStyleDeclaration对象与表示内联样式的CSSStyleDeclaration对象的区别:
1.计算样式的属性是只读的;
2.计算样式的值是绝对值,类似百分比和点之类相对的单位将全部转换为以'px'为后缀的字符串绝对值,其值是颜色的属性将以“rgb(#,#,#)”或“rgba(#,#,#,#)”的格式返回;
3.不计算复合属性,只基于最基础的属性,如不要查询margin,而单独查询marginTop等;
4.计算样式对象未定义cssText属性;
5.计算样式同时具有欺骗性,使用时需注意,在查询某些属性时的返回值不一定精准,如查询font-family;
6.IE9以下不支持getComputedStyle方法,IE的Element对象有currentStyle属性;

六、直接添加样式表
1.创建标签<style>添加一张内置样式表

var style1 = document.createElement('style');
 style1.innerHTML = 'body{color:red}#top:hover{background-color: red;color: white;}';
 document.head.appendChild(style1);

2.另一种是添加外部样式表,即在文档中添加一个link节点,然后将href属性指向外部样式表的URL

var link1 = document.createElement('link');
link1.setAttribute('rel', 'stylesheet');
link1.setAttribute('type', 'text/css');
link1.setAttribute('href', 'reset-min.css');
document.head.appendChild(link1);

七、window.matchMedia方法用来检查CSS的mediaQuery语句。各种浏览器的最新版本(包括IE 10+)都支持该方法,对于不支持该方法的老式浏览器,可以使用第三方函数库matchMedia.js;
下面是mediaQuery语句的一个例子:

@media all and (max-device-width: 700px) {
           body {background: #FF0;}
 
        }

window.matchMedia方法接受一个mediaQuery语句的字符串作为参数,返回一个MediaQueryList对象。该对象有以下两个属性:
media:返回所查询的mediaQuery语句字符串。
matches:返回一个布尔值,表示当前环境是否匹配查询语句。

var result = window.matchMedia('(max-width: 700px)');
    if (result.matches) {
      console.log('页面宽度小于等于700px');
    } else {
      console.log('页面宽度大于700px');
 
    }

 window.matchMedia方法返回的MediaQueryList对象有两个方法,用来监听事件:addListener方法和removeListener方法。如果mediaQuery查询结果发生变化,就调用指定的回调函数;

var mql = window.matchMedia("(max-width: 700px)");
    mql.addListener(mqCallback);// 指定回调函数
    mql.removeListener(mqCallback);// 撤销回调函数
 
    function mqCallback(mql) {
 
      if (mql.matches) {// 宽度小于等于700像素} 
 
      else { // 宽度大于700像素}
 
    }

本文参考:
MDN: https://developer.mozilla.org/zh-CN/docs/Web/API
阮一峰javascript参考:http://javascript.ruanyifeng.com/dom/css.html
javascript权威指南第六版

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS 屏蔽键盘不可用与鼠标右键不可用的方法
Nov 18 Javascript
使用javascript实现有效时间的控制,并显示将要过期的时间
Jan 02 Javascript
javascript创建createXmlHttpRequest对象示例代码
Feb 10 Javascript
JS图像无缝滚动脚本非常好用
Feb 10 Javascript
谈谈我对JavaScript DOM事件的理解
Dec 18 Javascript
Bootstrap Fileinput文件上传组件用法详解
May 10 Javascript
[原创]JS基于FileSaver.js插件实现文件保存功能示例
Dec 08 Javascript
JS将时间秒转换成天小时分钟秒的字符串
Jul 10 Javascript
vue实现商城秒杀倒计时功能
Dec 12 Javascript
vue实现商品列表的添加删除实例讲解
May 14 Javascript
Vue切换Tab动态渲染组件的操作
Sep 21 Javascript
JS中箭头函数与this的写法和理解
Jan 14 Javascript
浅谈JS继承_寄生式继承 &amp; 寄生组合式继承
Aug 16 #Javascript
jQuery EasyUI Tab 选项卡问题小结
Aug 16 #Javascript
jQuery3.0中的buildFragment私有函数详解
Aug 16 #Javascript
js 自带的 map() 方法全面了解
Aug 16 #Javascript
JavaScript实战之带收放动画效果的导航菜单
Aug 16 #Javascript
js 自带的sort() 方法全面了解
Aug 16 #Javascript
JavaScript实战之菜单特效
Aug 16 #Javascript
You might like
?生?D片??C字串
2006/12/06 PHP
mac下Apache + MySql + PHP搭建网站开发环境
2014/06/02 PHP
php curl 上传文件代码实例
2015/04/27 PHP
详解PHP的抽象类和抽象方法以及接口总结
2019/03/15 PHP
ASP小贴士/ASP Tips javascript tips可以当桌面
2009/12/10 Javascript
浅谈Javascript鼠标和滚轮事件
2012/06/27 Javascript
用JavaScript实现动画效果的方法
2013/07/20 Javascript
javascript中的=等号个数问题两个跟三个有什么区别
2013/10/23 Javascript
Area 区域实现post提交数据的js写法
2014/04/22 Javascript
Javascript实现Web颜色值转换
2015/02/05 Javascript
微信企业号开发之微信考勤Cookies的使用
2015/09/11 Javascript
jQuery实现监控页面所有ajax请求的方法
2015/12/10 Javascript
JavaScript面向对象精要(下部)
2017/09/12 Javascript
vue实现页面加载动画效果
2017/09/19 Javascript
JavaScript中正则表达式使数字、中文或指定字符高亮显示
2017/10/31 Javascript
javascript实现循环广告条效果
2017/12/12 Javascript
[57:24]LGD vs VGJ.T 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
[51:26]VP vs VG 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
教你如何将 Sublime 3 打造成 Python/Django IDE开发利器
2014/07/04 Python
Python读写Excel文件方法介绍
2014/11/22 Python
Python程序中使用SQLAlchemy时出现乱码的解决方案
2015/04/24 Python
深入解析Python中的list列表及其切片和迭代操作
2016/03/13 Python
python内置函数:lambda、map、filter简单介绍
2017/11/16 Python
Python的地形三维可视化Matplotlib和gdal使用实例
2017/12/09 Python
python 列表中[ ]中冒号‘:’的作用
2019/04/30 Python
python中安装django模块的方法
2020/03/12 Python
PyCharm Anaconda配置PyQt5开发环境及创建项目的教程详解
2020/03/24 Python
浅谈在django中使用filter()(即对QuerySet操作)时踩的坑
2020/03/31 Python
Selenium使用Chrome模拟手机浏览器方法解析
2020/04/10 Python
使用python处理题库表格并转化为word形式的实现
2020/04/14 Python
德国价格合理的品牌商品购物网站:averdo
2019/03/21 全球购物
工作决心书范文
2014/03/11 职场文书
房地产推广策划方案
2014/05/19 职场文书
中学生检讨书范文
2014/11/03 职场文书
质量保证书格式模板
2015/02/27 职场文书
在vue中import()语法不能传入变量的问题及解决
2022/04/01 Vue.js