使用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 相关文章推荐
一款利用html5和css3实现的3D滚动特效的教程
Jan 04 HTML / CSS
CSS3实现3D翻书效果
Jun 20 HTML / CSS
移动端适配 使px自动转换rem
Aug 26 HTML / CSS
CSS3实现红包抖动效果
Dec 23 HTML / CSS
canvas基础之图形验证码的示例
Jan 02 HTML / CSS
HTML5 语音搜索(淘宝店语音搜素)
Jan 03 HTML / CSS
检测浏览器是否支持html5视频的代码
Mar 28 HTML / CSS
使用HTML5技术开发一个属于自己的超酷颜色选择器
Sep 22 HTML / CSS
深入探究HTML5的History API
Jul 09 HTML / CSS
HTML5+lufylegend实现游戏中的卷轴
Feb 29 HTML / CSS
通过canvas转换颜色为RGBA格式及性能问题的解决
Nov 22 HTML / CSS
CSS精灵图的原理与使用方法介绍
Mar 17 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
非常好用的Zend Framework分页类
2014/06/25 PHP
thinkphp文件引用与分支结构用法实例
2014/11/26 PHP
PHP实现原比例生成缩略图的方法
2016/02/03 PHP
php简单压缩css样式示例
2016/09/22 PHP
phpMyAdmin无法登陆的解决方法
2017/04/27 PHP
利用PHP扩展Xhprof分析项目性能实践教程
2018/09/05 PHP
PHP正则之正向预查与反向预查讲解与实例
2020/04/06 PHP
关于全局变量和局部变量的那些事
2013/01/11 Javascript
jquery导航制件jquery鼠标经过变色效果示例
2013/12/05 Javascript
JavaScript Serializer序列化时间处理示例
2014/07/31 Javascript
jQuery将所有被选中的checkbox某个属性值连接成字符串的方法
2015/01/24 Javascript
win7下安装配置node.js+express开发环境
2015/12/06 Javascript
bootstrap学习使用(导航条、下拉菜单、轮播、栅格布局等)
2016/12/01 Javascript
完美解决手机网页中输入框被输入法遮挡的问题
2017/12/19 Javascript
利用vue + element实现表格分页和前端搜索的方法
2017/12/25 Javascript
使用 Element UI Table 的 slot-scope方法
2019/10/10 Javascript
微信小程序工具函数封装
2019/10/28 Javascript
[02:12]DOTA2英雄基础教程 变体精灵
2013/12/16 DOTA
python 将大文件切分为多个小文件的实例
2019/01/14 Python
Django admin.py 在修改/添加表单界面显示额外字段的方法
2019/08/22 Python
python实现智能语音天气预报
2019/12/02 Python
pycharm 2019 最新激活方式(pycharm破解、激活)
2020/09/22 Python
Django 返回json数据的实现示例
2020/03/05 Python
用python-webdriver实现自动填表的示例代码
2021/01/13 Python
详解Python Celery和RabbitMQ实战教程
2021/01/20 Python
超市后勤自我鉴定
2014/01/17 职场文书
舞蹈教师自荐信
2014/01/27 职场文书
出纳员岗位职责风险
2014/03/06 职场文书
《吃水不忘挖井人》教学反思
2014/04/15 职场文书
小学师德标兵先进事迹材料
2014/05/25 职场文书
2014教师党员个人自我评议
2014/09/20 职场文书
长城导游词
2015/01/30 职场文书
会计求职简历自我评价
2015/03/10 职场文书
单位提档介绍信
2015/10/22 职场文书
医务人员医德医风心得体会
2016/01/25 职场文书
古诗之感恩老师
2019/10/24 职场文书