使用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之UI元素状态伪类选择器实例演示
Aug 11 HTML / CSS
实列教程 一款基于jquery和css3的响应式二级导航菜单
Nov 13 HTML / CSS
CSS3中HSL和HSLA的简单使用示例
Jul 14 HTML / CSS
使用CSS3的appearance属性改变元素的外观的方法
Dec 12 HTML / CSS
CSS3 text-shadow实现文字阴影效果
Feb 24 HTML / CSS
CSS3制作彩色进度条样式的代码示例分享
Jun 23 HTML / CSS
详解Sticky Footer 绝对底部的两种套路
Nov 03 HTML / CSS
HTML5网页音乐播放器的示例代码
Nov 09 HTML / CSS
HTML5 video视频字幕的使用和制作方法
May 03 HTML / CSS
将SVG图引入到HTML页面的实现
Sep 20 HTML / CSS
关于html选择框创建占位符的问题
Jun 09 HTML / CSS
HTML基本元素标签介绍
Feb 28 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
PHP+redis实现的限制抢购防止商品超发功能详解
2019/09/19 PHP
js中判断文本框是否为空的两种方法
2011/07/31 Javascript
Javascript写入txt和读取txt文件示例
2014/02/12 Javascript
jQuery产品间断向下滚动效果核心代码
2014/05/08 Javascript
使用jquery解析XML的方法
2014/09/05 Javascript
javascript制作游戏开发碰撞检测的封装代码
2015/03/31 Javascript
javascript实现加载xml文件的方法
2015/11/24 Javascript
原生JS实现-星级评分系统的简单实例
2016/08/21 Javascript
AngularJS学习笔记(三)数据双向绑定的简单实例
2016/11/08 Javascript
jQuery插件FusionCharts绘制的2D帕累托图效果示例【附demo源码】
2017/03/28 jQuery
JavaScript之class继承_动力节点Java学院整理
2017/07/03 Javascript
JS 60秒后重新发送验证码的实例讲解
2017/07/26 Javascript
Vue.js中的图片引用路径的方式
2017/07/28 Javascript
JavaScript函数apply()和call()用法与异同分析
2018/08/10 Javascript
vue中利用simplemde实现markdown编辑器(增加图片上传功能)
2019/04/29 Javascript
Vue 3.0 前瞻Vue Function API新特性体验
2019/08/12 Javascript
Vue中通过Vue.extend动态创建实例的方法
2019/08/13 Javascript
浅谈layer的Icon样式以及一些常用的layer窗口使用方法
2019/09/11 Javascript
JavaScript Image对象实现原理实例解析
2020/08/26 Javascript
Python实现类继承实例
2014/07/04 Python
python 实现删除文件或文件夹实例详解
2016/12/04 Python
python返回数组的索引实例
2019/11/28 Python
Python imageio读取视频并进行编解码详解
2019/12/10 Python
python如何求数组连续最大和的示例代码
2020/02/04 Python
Python3中的f-Strings增强版字符串格式化方法
2020/03/04 Python
Python爬虫设置ip代理过程解析
2020/07/20 Python
详解pycharm配置python解释器的问题
2020/10/15 Python
使用Python快速打开一个百万行级别的超大Excel文件的方法
2021/03/02 Python
HTML5之SVG 2D入门1—SVG(可缩放矢量图形)概述
2013/01/30 HTML / CSS
AJAX检测用户名是否存在的方法
2021/03/24 Javascript
2014教师研修学习体会
2014/07/08 职场文书
餐厅服务员岗位职责
2015/02/09 职场文书
具结保证书范本
2015/05/11 职场文书
幼儿园保教工作总结2015
2015/10/15 职场文书
2016年党支部公开承诺书
2016/03/25 职场文书
Golang 字符串的常见操作
2022/04/19 Golang