使用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动画(开启gpu加速)
Dec 23 HTML / CSS
使用CSS3配合IE滤镜实现渐变和投影的效果
Sep 06 HTML / CSS
CSS3绘制不规则图形的一些方法示例
Nov 07 HTML / CSS
详解CSS3阴影 box-shadow的使用和技巧总结
Dec 03 HTML / CSS
CSS3 mask 遮罩的具体使用方法
Nov 03 HTML / CSS
HTML5实现表单自动验证功能实例代码
Jan 11 HTML / CSS
基于HTML5 FileSystem API的使用介绍
Apr 24 HTML / CSS
HTML5注册表单的自动聚焦与占位文本示例代码
Jul 19 HTML / CSS
解决HTML5中的audio在手机端和微信端的不能自动播放问题
Nov 04 HTML / CSS
HTML通过表单实现酒店筛选功能
May 18 HTML / CSS
解决flex布局中子项目尺寸不受flex-shrink限制
May 11 HTML / CSS
html中两种获取标签内的值的方法
Jun 10 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
第十一节 重载 [11]
2006/10/09 PHP
PHP控制网页过期时间的代码
2008/09/28 PHP
解析php下载远程图片函数 可伪造来路
2013/06/25 PHP
thinkphp缓存技术详解
2014/12/09 PHP
php通过修改header强制图片下载的方法
2015/03/24 PHP
从wamp到xampp的升级之路
2015/04/08 PHP
php动态添加url查询参数的方法
2015/04/14 PHP
php类自动装载、链式操作、魔术方法实现代码
2017/07/23 PHP
javascript中的float运算精度实例分析
2010/08/21 Javascript
jquery操作HTML5 的data-*的用法实例分享
2014/08/17 Javascript
Angular用来控制元素的展示与否的原生指令介绍
2015/01/07 Javascript
Js 获取当前函数参数对象的实现代码
2016/06/20 Javascript
在Docker快速部署Node.js应用的详细步骤
2016/09/02 Javascript
深入理解ES7的async/await的用法
2017/09/09 Javascript
默认浏览器设置及vue自动打开页面的方法
2018/09/21 Javascript
Vue infinite update loop的问题解决
2019/04/23 Javascript
微信小程序实现下拉刷新动画
2019/06/21 Javascript
生成无限制的微信小程序码的示例代码
2019/09/20 Javascript
jquery 遍历hash操作示例【基于ajax交互】
2019/10/12 jQuery
微信小程序反编译的实现
2020/12/10 Javascript
Python中优化NumPy包使用性能的教程
2015/04/23 Python
在Python中用split()方法分割字符串的使用介绍
2015/05/20 Python
python抽象基类用法实例分析
2015/06/04 Python
PYQT5设置textEdit自动滚屏的方法
2019/06/14 Python
python实现递归查找某个路径下所有文件中的中文字符
2019/08/31 Python
文件上传服务器-jupyter 中python解压及压缩方式
2020/04/22 Python
html5 桌面提醒:Notifycations应用介绍
2012/11/27 HTML / CSS
HTML5中在title标题标签里设置小图标的方法
2020/06/23 HTML / CSS
澳大利亚珍珠首饰购物网站:Vayo Pearls
2019/03/11 全球购物
PHP引擎php.ini参数优化深入讲解
2021/03/24 PHP
工程监理应届生求职信
2013/11/09 职场文书
保护环境建议书
2014/03/12 职场文书
计算机专业自荐信范文
2014/05/28 职场文书
中学生旷课检讨书500字
2014/10/29 职场文书
2015年质量管理工作总结范文
2015/05/18 职场文书
入党积极分子考察意见
2015/06/02 职场文书