在html5新增的classList之前, 操作元素的class用的是className这个属性,而如果要向jquery封装的hasClass, removeClass, addClass, toggleClass一样优雅的操作calssName, 在以前我们要对className封装处理,如下, 下面的代码你未必能看得懂运行流程,但应该能看懂功能部分,这几段函数是取自我录制的一套视频中,讲解DOM框架封装的一部分

 gQuery.prototype.hasClass = function (obj, cName) {
// <div class="abc"> <div class="hello abc def"></div> <div class="hello def abc"></div>
return obj.className.match(new RegExp('(\\s|^)' + cName + '(\\s|$)'));
} gQuery.prototype.addClass = function (cName) {
for (var i = 0; i < this.elements.length; i++) {
if (!this.hasClass(this.elements[i], cName)) {
// hello abc // abc
this.elements[i].className += " " + cName;
this.elements[i].className = this.trim(this.elements[i].className);
}
}
return this;
} gQuery.prototype.removeClass = function (cName) {
for (var i = 0; i < this.elements.length; i++) {
if (this.hasClass(this.elements[i], cName)) {
var re = new RegExp('(\\s|^)' + cName + '(\\s|$)');
this.elements[i].className = this.elements[i].className.replace(re, " ");
this.elements[i].className = this.trim(this.elements[i].className);
}
}
return this;
} gQuery.prototype.toggleClass = function (cName) {
for (var i = 0; i < this.elements.length; i++) {
if (this.hasClass(this.elements[i], cName)) {
this.removeClass(cName);
} else {
this.addClass(cName);
}
}
return this;
}

这里,我还写了一个独立的删除某个class的功能:

 <div class="box1 box2 box3">this is a test string</div>
<input type="button" value="移除某个class">
<script>
var oDiv = document.querySelector("div"),
classNames = '',
oBtn = document.querySelector("input");
oBtn.onclick = function(){
classNames = oDiv.className.split(/\s+/);
var pos = -1, i, len;
for( i = 0, len = classNames.length; i < len; i++ ) {
if( classNames[i] == 'box2' ) {
pos = i;
break;
}
}
classNames.splice( i, 1 );
oDiv.className = classNames.join( " " );
} </script>

思路非常的简单,获取div元素中的所有class, 用split 按空格切割,就会得到[box1,box2,box3]这样的数组, 然后遍历判断,是否有box2这个class?

找到之后就把当前数组的索引记下来,最后再用splice把该class从数组删除得到[box1,box3] 然后把数组的每一项用join函数中的空格连接,再赋值

给元素的className.

而在html5中,每个元素都有classList这个属性, classList是一个类数组结构, 提供了4个操作class的方法: add,remove,toggle,contains,

看到这几个英文单词,你已经知道什么意思了吧,尤其对于使用过jquery的朋友

add( 添加class),   remove( 删除class), toggle( 切换class) contains( 判断是否包含某个class )

 <div id="box" class="box1 box2 box3">this is a test string</div>
<input type="button" value="添加class" id="btn-add">
<input type="button" value="移除class" id="btn-remove">
<input type="button" value="切换class" id="btn-toggle">
<script>
var G = function (id) { return document.querySelector(id); }
var oBtnAdd = G('#btn-add'),
oBtnRemove = G('#btn-remove'),
oBtnToggle = G('#btn-toggle'),
oBox = G('#box');
oBtnAdd.onclick = function(){
oBox.classList.add( 'box4' );
}
oBtnRemove.onclick = function(){
if( oBox.classList.contains('box1') ) {
oBox.classList.remove( 'box1' );
}
}
oBtnToggle.onclick = function(){
oBox.classList.toggle( 'box4' );
}
</script>

HTML5新特性:元素的classList属性与应用的更多相关文章

  1. html5新特性contenteditable 属性更容易实现动态表单

    介绍html5新特性的一个属性:contenteditable 作用域全局.所有的块标签都可以,例如:span.p.div.td等标签.但是,不可以作用域<br/>类型的标签. conte ...

  2. 转: HTML5新特性之Mutation Observer

    转: HTML5新特性之Mutation Observer Mutation Observer是什么 Mutation Observer(变动观察器)是监视DOM变动的接口.当DOM对象树发生任何变动 ...

  3. web全栈架构师[笔记] — 03 html5新特性

    HTML5新特性 一.geolocation PC端 精度比较低 通过IP库定位 移动端 通过GPS window.navigator.geolocation 单次 getCurrentPositio ...

  4. HTML5新特性:范围样式

    原文出处:http://blog.csdn.net/hfahe/article/details/7381141        Chromium 最近实现了一个HTML5的新特性:范围样式,又叫做< ...

  5. html5新特性与用法大全了解一下

    有好多小伙伴私聊我问我html5新特性 和用法,下面我给大家具体介绍一下html5都新加了哪些新特性,下面我给大家总结一下. 1)新的语义标签 footer header 等等2)增强型表单 表单2. ...

  6. 第二季第八天 HTML5新特性

    在函数内部window.a =  a  在全局中就可以拿到这个变量 变量命名.作为函数的参数的时候要详细.调用的时候可以简单点 做全局变量的两个方案 1.绑在标签上data 2.闭包 视频一般都是二进 ...

  7. 前端进阶系列(三):HTML5新特性

    HTML5 是对 HTML 标准的第五次修订.其主要的目标是将互联网语义化,以便更好地被人类和机器阅读,并同时提供更好地支持各种媒体的嵌入.HTML5 的语法是向后兼容的.现在国内普遍说的 H5 是包 ...

  8. HTML5新特性-- -定时器

    一.定时器:一次性定时器/周期性定时器 #requestAnimationFrame 智能定时器 #此定时器主要使用范围:动画和游戏中 特点: setTimeout(fn,500); setInter ...

  9. html5新特性

    这一篇博文不会告诉你怎么去使用html5的新特性,只会给你总结一下新特性------对于好学的人可以把这篇文章当做一个目录 对于初接触的人来说是一个导向 对于已经接触过的人来说是一个检测你掌握程度的检 ...

随机推荐

  1. javascript设计模式——享元模式

    前面的话 享元(flyweight)模式是一种用于性能优化的模式,“fly”在这里是苍蝇的意思,意为蝇量级.享元模式的核心是运用共享技术来有效支持大量细粒度的对象.如果系统中因为创建了大量类似的对象而 ...

  2. 自学Python全栈开发的第二次笔记(Python需要注意的地方)

    好几天没写blog了,今天整理整理.写blog一定要坚持下去.     Python解释器 #!/usr/bin/env python #-*-coding:utf-8-*-   #  无效的内容,只 ...

  3. 是否是有效的dom节点--轮子代码

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title> ...

  4. 【swift-总结】函数

    swift的函数在swift2中的使用改变了不少 /** *param: personName 參数 *returns: String为返回值 */ func sayHello(personName: ...

  5. 关于系统首页绘制问题(ext布局+c#后台加入数据)经html输出流输出响应client

    关于系统首页绘制问题,业务需求 TODO 绘制系统首页(Main.aspx) 採用的技术:functioncharts+jquery+ext布局+c#+html 解说篇:1,服务端aspx,2,服务端 ...

  6. python内置函数(四)

    python内部提供了非常多内建函数. 以下让我们从a-z開始学习python的内建函数 1.1 id(object) 返回对象的id(身份),返回的这个是一个整数(integer)是唯一的,在这个对 ...

  7. JAVA入门[8]-测试mybatis

    上一节通过mybatis-generator自动生成了CategoryMapper接口,pojo等类,接下来我们写几个简单的测试来进行调用. 一.添加依赖 <dependency> < ...

  8. 接触HTML和CSS心得体会

    1.HTML 它负责网页的三个要素之中的结构: HTML使用标签的形式来标识网页中的不同组成部分 <!DOCTYPE html> <html> <head> < ...

  9. 迭代var()内置函数的时候出现RuntimeError: dictionary changed size during iteration的解决办法

    下午看了Mr Seven的教学视频,其中有一段讲全局变量的视频,迭代输出全局变量的时候报错了. 视频中的做法: for k,v in vars().items(): print(k) 打印结果 for ...

  10. Java Restful Web Service 学习指南

    Restful是一种架构style,目前常说的有restful web service, resultful http.现在热搜榜的微服务,大多数会采用Restful方式. JAX-RS 作为一个Re ...