使用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的区别示例介绍
Mar 10 HTML / CSS
CSS3+Sprite实现僵尸行走动画特效源码
Jan 27 HTML / CSS
HTML5+CSS3 实现灵动的动画 TAB 切换效果(DEMO)
Sep 15 HTML / CSS
CSS3田字格列表的样式编写方法
Nov 22 HTML / CSS
浅谈Html5中视频 音频标签 进度条的问题
Jul 26 HTML / CSS
使用phonegap播放音频的实现方法
Mar 31 HTML / CSS
canvas进阶之贝塞尔公式推导与物体跟随复杂曲线的轨迹运动
Jan 10 HTML / CSS
微信端html5页面调用分享接口示例
Mar 14 HTML / CSS
HTML5 input新增type属性color颜色拾取器的实例代码
Aug 27 HTML / CSS
Html5监听手机摇一摇事件的实现
Nov 07 HTML / CSS
amaze ui 的使用详细教程
Aug 19 HTML / CSS
HTML+CSS实现导航条下拉菜单的示例代码
Aug 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
解析link_mysql的php版
2013/06/30 PHP
简单的php中文转拼音的实现代码
2014/02/11 PHP
PHP同时连接多个mysql数据库示例代码
2014/03/17 PHP
ThinkPHP提交表单时默认自动转义的解决方法
2014/11/25 PHP
Codeigniter控制器controller继承问题实例分析
2016/01/19 PHP
PHP单例模式与工厂模式详解
2017/08/29 PHP
PHP fopen函数用法实例讲解
2019/02/15 PHP
Laravel框架下载,安装及路由操作图文详解
2019/12/04 PHP
js表格分页实现代码
2009/09/18 Javascript
js弹出层(jQuery插件形式附带reLoad功能)
2013/04/12 Javascript
Vue2实现组件props双向绑定
2016/12/02 Javascript
less简单入门(CSS 预处理语言)
2017/03/08 Javascript
AngularJS动态绑定ng-options的ng-model实例代码
2017/06/21 Javascript
js input输入百分号保存数据库失败的解决方法
2018/05/26 Javascript
Express之托管静态文件的方法
2018/06/01 Javascript
优雅的elementUI table单元格可编辑实现方法详解
2018/12/23 Javascript
JavaScript cookie原理及使用实例
2020/05/08 Javascript
Vue父子组件传值的一些坑
2020/09/16 Javascript
Python使用turtule画五角星的方法
2015/07/09 Python
Python中在脚本中引用其他文件函数的实现方法
2016/06/23 Python
Python多层装饰器用法实例分析
2018/02/09 Python
python主线程捕获子线程的方法
2018/06/17 Python
详解Python循环作用域与闭包
2019/03/21 Python
python 实现"神经衰弱"翻牌游戏
2020/11/09 Python
python中的列表和元组区别分析
2020/12/30 Python
html5跨域通讯之postMessage的用法总结
2013/11/07 HTML / CSS
巴西服装和鞋子购物网站:Marisa
2018/10/25 全球购物
linux面试题参考答案(9)
2016/01/29 面试题
党员公开承诺书内容
2014/05/20 职场文书
党委领导班子整改方案
2014/09/30 职场文书
2016继续教育培训学习心得体会
2016/01/19 职场文书
24句精辟的现实社会语录,句句扎心,道尽人性
2019/08/29 职场文书
MySQL主从复制断开的常用修复方法
2021/04/07 MySQL
python控制台打印log输出重复的解决方法
2021/05/14 Python
python 实现图片特效处理
2022/04/03 Python
Win10系统搭建ftp文件服务器详细教程
2022/08/05 Servers