使用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 完美实现圆角效果
Jul 13 HTML / CSS
利用CSS3的定位页面元素
Aug 29 HTML / CSS
css3中flex布局宽度不生效的解决
Dec 09 HTML / CSS
html5组织文档结构_动力节点Java学院整理
Jul 11 HTML / CSS
详解利用canvas实现环形进度条的方法
Jun 12 HTML / CSS
html5中canvas学习笔记2-判断浏览器是否支持canvas
Jan 06 HTML / CSS
html5开发之viewport使用
Oct 17 HTML / CSS
针对HTML5的Web Worker使用攻略
Jul 12 HTML / CSS
Web前端页面跳转并取到值
Apr 24 HTML / CSS
HTML中meta标签及Keywords
Apr 15 HTML / CSS
canvas绘制太极图的实现示例
Apr 29 HTML / CSS
CSS实现鼠标悬浮动画特效
May 07 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
apache mysql php 源码编译使用方法
2012/05/03 PHP
克隆一个新项目的快捷方式
2013/04/10 PHP
php笔记之:php函数range() round()和list()的使用说明
2013/04/26 PHP
PHP屏蔽关键字实现方法
2016/11/17 PHP
Yii2框架配置文件(Application属性)与调试技巧实例分析
2019/05/27 PHP
javascript 从if else 到 switch case 再到抽象
2010/07/17 Javascript
jQuery Autocomplete自动完成插件
2010/07/17 Javascript
基于JQuery的模拟苹果桌面Dock效果(稳定版)
2012/10/15 Javascript
IE关闭时判断及AJAX注销案例学习
2013/02/18 Javascript
新增加的内容是如何将div的scrollbar自动移动最下面
2014/01/02 Javascript
jquery实现邮箱自动填充提示功能
2015/11/17 Javascript
微信小程序 swiper组件轮播图详解及实例
2016/11/16 Javascript
jQuery简介_动力节点Java学院整理
2017/07/04 jQuery
用vuex写了一个购物车H5页面的示例代码
2018/12/04 Javascript
vue开发环境配置跨域的方法步骤
2019/01/16 Javascript
深入了解JavaScript 的 WebAssembly
2019/06/15 Javascript
JavaScript实现随机五位数验证码
2019/09/27 Javascript
解决layui下拉框监听问题(监听不到值的变化)
2019/09/28 Javascript
[02:28]DOTA2英雄基础教程 灰烬之灵
2013/12/19 DOTA
[46:44]DOTA2-DPC中国联赛 正赛 Ehome vs PSG.LGD BO3 第二场 3月7日
2021/03/11 DOTA
Python实现对PPT文件进行截图操作的方法
2015/04/28 Python
Python Property属性的2种用法
2015/06/21 Python
python用reduce和map把字符串转为数字的方法
2016/12/19 Python
python程序变成软件的实操方法
2019/06/24 Python
HTML5的结构和语义(4):语义性的内联元素
2008/10/17 HTML / CSS
Speedo美国:澳大利亚顶尖泳衣制造商
2016/08/03 全球购物
日本著名化妆品零售网站:Cosme Land
2019/03/01 全球购物
安德玛比利时官网:Under Armour比利时
2019/08/28 全球购物
行政总经理岗位职责
2013/12/05 职场文书
电子商务优秀毕业生求职信
2014/07/11 职场文书
律师授权委托书范本
2014/10/07 职场文书
2015年幼儿园新年寄语
2014/12/08 职场文书
小学班主任教育随笔
2015/08/15 职场文书
详解如何用Python实现感知器算法
2021/06/18 Python
使用Spring处理x-www-form-urlencoded方式
2021/11/02 Java/Android
使用 Koa + TS + ESLlint 搭建node服务器的过程详解
2022/05/30 NodeJs