使用HTML5里的classList操作CSS类


Posted in HTML / CSS onJune 28, 2016

在JavaScript和JavaScript工具库里征战多年,我经常有这样的遐想:什么时候现代浏览器里能提供一些辅助方法和类库,替代那些JavaScript工具库,比如jQuery,让我们用浏览器原生的方法替代它们。我知道浏览器必定会向这个方向改进,但这个进化过程不会很迅速,而且各种浏览器需要共同做这样的革新,火狐浏览器、谷歌浏览器、特别是IE,只有当这些主流浏览器都具备了这样的功能,我们的愿望才算真正的实现。好消息是,其中有一个这样的功能已经被加入到了HTML5 API里:classList

在HTML5 API里,页面DOM里的每个节点上都有一个classList对象,程序员可以使用里面的方法新增、删除、修改节点上的CSS类。使用classList,程序员还可以用它来判断某个节点是否被赋予了某个CSS类。

Element.classList

这个classList对象里有很多有用的方法:

XML/HTML Code复制内容到剪贴板
  1. {   
  2.  length: {number}, /* # of class on this element */   
  3.  add: function() { [native code] },   
  4.  contains: function() { [native code] },   
  5.  item: function() { [native code] }, /* by index */   
  6.  remove: function() { [native code] },   
  7.  toggle: function() { [native code] }   
  8. }   
  9.   

正如你上面看到的,Element.classList类很小,但里面的每个方法都很有用。

新增CSS类

使用add方法,你可以往页面元素是新增一个或多个css类:

myDiv.classList.add('myCssClass');

删除一个CSS类

使用remove方法,你可以删除单个CSS类:

myDiv.classList.remove('myCssClass');

你可以在这个方法里一次传入多个类名,用空格分开,但执行的结果很有可能不是你预期的。

反转CSS类的有无

myDiv.classList.toggle('myCssClass'); //现在是增加
myDiv.classList.toggle('myCssClass'); //现在是删除

这个方法的作用就是,当myDiv元素上没有这个CSS类时,它就新增这个CSS类;如果myDiv元素已经有了这个CSS类,它就是删除它。就是反转操作。

检查是否含有某个CSS类

myDiv.classList.contains('myCssClass'); //returns true or false

目前所有的现代浏览器(火狐浏览器,谷歌浏览器等)都支持这个classList类,所以,相信新型的javaScript类库里都会使用classList类来操作页面CSS类,而不需像以前一样去分析元素节点的class属性!

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

HTML / CSS 相关文章推荐
在css3中background-clip属性与background-origin属性的用法介绍
Nov 13 HTML / CSS
CSS3 滤镜 webkit-filter详细介绍及使用方法
Dec 27 HTML / CSS
用css3实现当鼠标移进去时当前亮其他变灰效果
Apr 08 HTML / CSS
用CSS3打造HTML5的Logo(实现代码)
Jun 16 HTML / CSS
微信浏览器取消缓存的方法
Mar 28 HTML / CSS
HTML5 localStorage使用总结
Feb 22 HTML / CSS
HTML5 canvas 瀑布流文字效果的示例代码
Jan 31 HTML / CSS
使用HTML5和CSS3制作一个模态框的示例
Mar 07 HTML / CSS
详解canvas绘制网络字体几种方法
Aug 27 HTML / CSS
HTML5实现无刷新修改URL的方法
Nov 14 HTML / CSS
html5简介及新增功能介绍
May 18 HTML / CSS
html5跳转小程序wx-open-launch-weapp踩坑
Dec 02 HTML / CSS
HTML5 canvas基本绘图之图形组合
Jun 27 #HTML / CSS
HTML5不支持标签和新增标签详解
Jun 27 #HTML / CSS
HTML5 canvas基本绘图之文字渲染
Jun 27 #HTML / CSS
HTML5 canvas基本绘图之绘制曲线
Jun 27 #HTML / CSS
HTML5 canvas基本绘图之图形变换
Jun 27 #HTML / CSS
HTML5 canvas基本绘图之填充样式实现
Jun 27 #HTML / CSS
HTML5 canvas基本绘图之绘制线条
Jun 27 #HTML / CSS
You might like
PHP-CGI进程CPU 100% 与 file_get_contents 函数的关系分析
2011/08/15 PHP
PHP中::、->、self、$this几种操作符的区别介绍
2013/04/24 PHP
TP5多入口设置实例讲解
2020/12/15 PHP
jquery animate实现鼠标放上去显示离开隐藏效果
2013/07/21 Javascript
浅析函数声明和函数表达式——函数声明的声明提前
2016/05/03 Javascript
JS 日期与时间戮相互转化的简单实例
2016/06/22 Javascript
vue制作加载更多功能的正确打开方式
2016/10/12 Javascript
详解angular中的作用域及继承
2017/05/31 Javascript
JavaScript定时器setTimeout()和setInterval()详解
2017/08/18 Javascript
详解JS中的this、apply、call、bind(经典面试题)
2017/09/19 Javascript
vue element-ui 绑定@keyup事件无效的解决方法
2018/03/09 Javascript
深入理解js 中async 函数的含义和用法
2018/05/13 Javascript
angular 组件通信的几种实现方式
2018/07/13 Javascript
详解vue中localStorage的使用方法
2018/11/22 Javascript
vue中监听路由参数的变化及方法
2019/12/06 Javascript
vue实现tab栏点击高亮效果
2020/08/19 Javascript
Python 深入理解yield
2008/09/06 Python
Python正则表达式匹配HTML页面编码
2015/04/08 Python
Python比较配置文件的方法实例详解
2019/06/06 Python
使用python将多个excel文件合并到同一个文件的方法
2019/07/09 Python
windows下python虚拟环境virtualenv安装和使用详解
2019/07/16 Python
在Tensorflow中查看权重的实现
2020/01/24 Python
Python sorted排序方法如何实现
2020/03/31 Python
python中查看.db文件中表格的名字及表格中的字段操作
2020/07/07 Python
python通过cython加密代码
2020/12/11 Python
Python 多进程原理及实现
2020/12/21 Python
校三好学生主要事迹
2014/01/11 职场文书
网上书店创业计划书
2014/01/12 职场文书
作弊检讨书1000字
2014/02/01 职场文书
小学教学随笔感言
2014/02/26 职场文书
中学生家长评语大全
2014/04/16 职场文书
奥巴马开学演讲稿
2014/05/15 职场文书
本科生求职信
2014/06/17 职场文书
贸易经济专业自荐书
2014/06/29 职场文书
大学团日活动总结书
2015/05/11 职场文书
公司趣味运动会开幕词
2016/03/04 职场文书