HTML5新特性:元素的classList属性与应用
在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属性与应用的更多相关文章
- html5新特性contenteditable 属性更容易实现动态表单
介绍html5新特性的一个属性:contenteditable 作用域全局.所有的块标签都可以,例如:span.p.div.td等标签.但是,不可以作用域<br/>类型的标签. conte ...
- 转: HTML5新特性之Mutation Observer
转: HTML5新特性之Mutation Observer Mutation Observer是什么 Mutation Observer(变动观察器)是监视DOM变动的接口.当DOM对象树发生任何变动 ...
- web全栈架构师[笔记] — 03 html5新特性
HTML5新特性 一.geolocation PC端 精度比较低 通过IP库定位 移动端 通过GPS window.navigator.geolocation 单次 getCurrentPositio ...
- HTML5新特性:范围样式
原文出处:http://blog.csdn.net/hfahe/article/details/7381141 Chromium 最近实现了一个HTML5的新特性:范围样式,又叫做< ...
- html5新特性与用法大全了解一下
有好多小伙伴私聊我问我html5新特性 和用法,下面我给大家具体介绍一下html5都新加了哪些新特性,下面我给大家总结一下. 1)新的语义标签 footer header 等等2)增强型表单 表单2. ...
- 第二季第八天 HTML5新特性
在函数内部window.a = a 在全局中就可以拿到这个变量 变量命名.作为函数的参数的时候要详细.调用的时候可以简单点 做全局变量的两个方案 1.绑在标签上data 2.闭包 视频一般都是二进 ...
- 前端进阶系列(三):HTML5新特性
HTML5 是对 HTML 标准的第五次修订.其主要的目标是将互联网语义化,以便更好地被人类和机器阅读,并同时提供更好地支持各种媒体的嵌入.HTML5 的语法是向后兼容的.现在国内普遍说的 H5 是包 ...
- HTML5新特性-- -定时器
一.定时器:一次性定时器/周期性定时器 #requestAnimationFrame 智能定时器 #此定时器主要使用范围:动画和游戏中 特点: setTimeout(fn,500); setInter ...
- html5新特性
这一篇博文不会告诉你怎么去使用html5的新特性,只会给你总结一下新特性------对于好学的人可以把这篇文章当做一个目录 对于初接触的人来说是一个导向 对于已经接触过的人来说是一个检测你掌握程度的检 ...
随机推荐
- javascript设计模式——装饰者模式
前面的话 在程序开发中,许多时候都并不希望某个类天生就非常庞大,一次性包含许多职责.那么可以使用装饰者模式.装饰者模式可以动态地给某个对象添加一些额外的职责,而不会影响从这个类中派生的其他对象.本文将 ...
- Python爬虫(十四)_BeautifulSoup4 解析器
CSS选择器:BeautifulSoup4 和lxml一样,Beautiful Soup也是一个HTML/XML的解析器,主要的功能也是如何解析和提取HTML/XML数据. lxml只会局部遍历,而B ...
- cocos2d+TexturePackerGUI动画制作
转载请注明出处:http://blog.csdn.net/oyangyufu/article/details/25168047 程序效果图: 1.下载安装TexturePackerGUI 地址:htt ...
- Jenkins具体安装与构建部署使用教程
Jenkins是一个开源软件项目.旨在提供一个开放易用的软件平台,使软件的持续集成变成可能. Jenkins是基于Java开发的一种持续集成工具,用于监控持续反复的工作,功能包含:1.持续的软件版本号 ...
- 关于MySql中使用IFNULL()函数失效的问题。
今天在学习时,碰到一个问题:在联表查询取得结果后,如果取得的结果是空值,则给一个默认值,如果不是空值,则返回这个值. 下面我们来看看业务场景: 在menu表中: 存储的是前端页面的菜单配置,注意成员权 ...
- 抓包工具 fiddler
1. 抓包软件 TCP 外挂: 1. 解包工具 2.抓包工具 HTTP 1.前后端交互过程 2.学习的作用 3.模拟网络情况 2 http client server 没有加密 https 证书 非 ...
- ATM程序设计
package com.arthur.object; import java.util.Scanner; /*** * 简单的ATM存取款程序 1.登陆页面 2.登陆 3.菜单:1,查询,2,存款,3 ...
- pytho核心编程2-1中代码运行问题
书籍是<python核心编程>第三版,学习环境py3.6 2-1 时间戳服务器 附源代码: from socket import * from time import ctime HOST ...
- Mac OS 终端利器 iTerm2
之前一直使用 Mac OS 自带的终端,用起来虽然有些不太方便,但总体来说还是可以接受的,是有想换个终端的想法,然后今天偶然看到一个终端利器 iTerm2,发现真的很强大,也非常的好用,按照网上配置了 ...
- 【bird-front】前端框架介绍
bird前端项目,基于react.antd.antd-admin,封装常用数据组件,细粒度权限解决方案. bird-front是基于react的后台管理系统前端项目,框架构建部分严重借鉴于antd管理 ...