使用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选择器的研究(详解)
Sep 16 HTML / CSS
CSS3制作精致的照片墙特效
Jun 07 HTML / CSS
CSS3 倾斜的网页图片库实例教程
Nov 14 HTML / CSS
定义css设备类型-Media Queries图表简介及使用方法
Jan 21 HTML / CSS
使用css创建三角形 使用CSS3创建3d四面体原理及代码(html5实践)
Jan 06 HTML / CSS
html5 Canvas画图教程(4)—未闭合的路径及渐变色的填充方法
Jan 09 HTML / CSS
html5的canvas元素使用方法介绍(画矩形、画折线、圆形)
Apr 14 HTML / CSS
详解html5 postMessage解决跨域通信的问题
Aug 17 HTML / CSS
div或img图片高度随宽度自适应的方法
Feb 06 HTML / CSS
详解如何解决H5开发使用wx.hideMenuItems无效果不生效
Jan 20 HTML / CSS
纯html+css实现打字效果
Aug 02 HTML / CSS
clear 万能清除浮动(clearfix:after)
May 21 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
DC这些乐高系列动画电影你看过几部?
2020/04/09 欧美动漫
DEDE采集大师官方留后门的删除办法
2011/01/08 PHP
解析PHP处理换行符的问题 \r\n
2013/06/13 PHP
Yii1.1框架实现PHP极光推送消息通知功能
2018/09/06 PHP
PHP使用PDO 连接与连接管理操作实例分析
2020/04/21 PHP
根据分辨率不同,调用不同的css文件
2006/08/25 Javascript
用于判断用户注册时,密码强度的JS代码
2009/01/01 Javascript
javascript动态添加样式(行内式/嵌入式/外链式等规则)
2013/06/24 Javascript
js实现数组去重、判断数组以及对象中的内容是否相同
2013/11/29 Javascript
js格式化金额可选是否带千分位以及保留精度
2014/01/28 Javascript
Javascript异步编程模型Promise模式详细介绍
2014/05/08 Javascript
jQuery级联操作绑定事件实例
2014/09/02 Javascript
JS基于VML技术实现的五角星礼花效果代码
2015/10/26 Javascript
javascript嵌套函数和在函数内调用外部函数的区别分析
2016/01/31 Javascript
Bootstrap弹出框(modal)垂直居中的问题及解决方案详解
2016/06/12 Javascript
每日十条JavaScript经验技巧(一)
2016/06/23 Javascript
浅谈js多维数组和hash数组定义和使用
2016/07/27 Javascript
简单的jQuery拖拽排序效果的实现(增强动态)
2017/02/09 Javascript
JavaScript实现省市县三级级联特效
2017/05/16 Javascript
浅谈vue项目可以从哪些方面进行优化
2018/05/05 Javascript
Vue.js项目实战之多语种网站的功能实现(租车)
2019/08/07 Javascript
小程序和web画三角形实现解析
2019/09/02 Javascript
JavaScript计算正方形面积
2019/11/26 Javascript
[02:28]DOTA2英雄基础教程 狼人
2013/12/23 DOTA
详解Python下ftp上传文件linux服务器
2018/06/21 Python
使用python验证代理ip是否可用的实现方法
2018/07/25 Python
python生成多个只含0,1元素的随机数组或列表的实例
2018/11/12 Python
python 通过手机号识别出对应的微信性别(实例代码)
2019/12/22 Python
Python3标准库之dbm UNIX键-值数据库问题
2020/03/24 Python
Python面向对象特殊属性及方法解析
2020/09/16 Python
英国床垫和床架购物网站:Bedman
2019/11/04 全球购物
小学评语大全
2014/04/22 职场文书
学校志愿者活动总结
2014/06/27 职场文书
趣味运动会新闻稿
2015/07/17 职场文书
优秀共产党员主要事迹材料
2015/11/05 职场文书
nginx安装以及配置的详细过程记录
2021/09/15 Servers