一、classList API 是什么

  1. 属于 DOM API,HTML5 引入,用来操作 HTML 标签的 class 属性值。
  2. classList 属性是一个只读的类数组对象,“实时”地代表了元素的类名集合。
  3. classList 对象上定义了 6 个实用的操作 class 属性值的方法。

二、classList 对象上的属性和方法

属性:

length:返回当前类列表中类的个数。

方法:

  1. add(class1, class2, ...):添加类
  2. remove(class1, class2, ...):删除类
  3. toggle(class[, force]):当前类列表中如果不存在指定的类,则执行添加类操作,返回 true;否则执行删除类操作,返回 false。force 是一个函数,决定 toggle 方法最终执行何种操作——当函数返回 true 时,执行添加类操作,返回 false,执行删除类操作。
  4. contains(class):是否包含指定类。
  5. item(index):返回当前类列表中指定位置的类名。
  6. toString():返回当前类列表的字符串表示。

接下来会举些使用上述方法和属性的例子(这里有一个 线上的例子 ),这些例子都会用到下面这段 HTML 代码。

<span id="element" class="description"></span>

2.1 add() 方法

添加一个类名:

document.getElementById('element').classList.add('red');
// class="description red"

添加多个类名:

document.getElementById('element').classList.add('red', 'bold');
// class="description red bold"

{提示} 如果提供的类名已存在,就不会重复添加。

2.2 remove() 方法

删除一个类名:

document.getElementById('element').classList.remove('description');
// class=""

删除多个类名:

document.getElementById('element').classList.remove('description', 'red');
// class=""

2.3 toggle() 方法

document.getElementById('element').classList.toggle('description');
// class="" document.getElementById('element').classList.toggle('description');
// class="description"

2.4 item() 方法

document.getElementById('element').classList.item(0);
// 返回 "description" document.getElementById('element').classList.item(2);
// 返回 null

2.5 contains 方法

if (document.getElementById('element').classList.contains('description')) {
// 一些逻辑代码……
} else {
// 不同的逻辑代码……
}

2.6 toString() 方法

console.log(document.getElementById('element').classList.toString());
// 打印 "description" document.getElementById('element').classList.add('red', 'bold');
console.log(document.getElementById('element').classList.toString());
// 打印 "description red bold"

2.7 length 属性

console.log(document.getElementById('element').classList.length);
// 打印 1

浏览器兼容性

IE10+ 和其他所有浏览器。其中 IE10+(包括土鳖 UC)属于部分支持,不支持的内容包括:

  1. 不支持 SVG 或 MathML 元素。
  2. 不支持 toggle 方法的第二个参数。
  3. 不支持多参数形式的 add()remove() 方法。

不过都是小事,可以使用 polyfill 解决。

参考链接

https://www.sitepoint.com/exploring-classlist-api/

(完)

使用 classList API的更多相关文章

  1. [Javascript] Manipulate the DOM with the classList API

    Learn how to add, remove and test for CSS classes using the classList API. It's more powerful than u ...

  2. HTML5 classList API接口

    原文地址:HTML5 classList API 原文日期: 2010年07月13日 翻译日期: 2013年08月23日 当我陷入JavaScrip和JavaScript类库框架之中时,我总是有种希望 ...

  3. 温习classList api

    有道题是一个removeClass的功能,代码里是正则分隔了传入的name,根据name的个数,循环移除掉,让寻找bug..看了了这几行代码,首先想到的是我会如何去优化. 如果看代码一两分钟就能找到公 ...

  4. HTML5 classList API

    Having thrust myself into the world of JavaScript and JavaScript Libraries, I've often wondered: Whe ...

  5. [转]HTML5 classList API

    Having thrust myself into the world of JavaScript and JavaScript Libraries, I've often wondered: Whe ...

  6. HTML5的classList API优化对样式名className的操作

    //添加一个class elem.classList.add(classname); //删除一个class elem.classList.remove(classname); //判断一个class ...

  7. element.dataset API

    不久之前我向大家展示了非常有用的classList API,它是一种HTML5里提供的原生的对页面元素的CSS类进行增.删改的接口,完全可以替代jQuery里的那些CSS类操作方法.而另外一个非常有用 ...

  8. H5新增属性classList

    H5新增属性classList h5中新增了一个classList,原生js可以通过它来判断获取dom节点有无某个class. classList是html元素对象的成员,它的使用非常简单,比如 co ...

  9. h5的classList对象

    H5新增属性classList h5中新增了一个classList,原生js可以通过它来判断获取dom节点有无某个class. classList是html元素对象的成员,它的使用非常简单,比如 co ...

随机推荐

  1. 1109. Group Photo (25)

    Formation is very important when taking a group photo. Given the rules of forming K rows with N peop ...

  2. tests

    test

  3. Sqoop-从hive导出分区表到MySQL

    经多次验证,发现并没有特殊的方法能够直接把多个分区一次性读入,并插入MySQL的方法,以后发现会在此添加. Sqoop只提供了从MySQL导入到HIVE分区表的相关参数,反向并无特别参数. 从HIVE ...

  4. 四、Jmeter--参数化

    一.CSV 参数化 1.我们做性能测试需要并发多个用户,为了真实模拟用户行为,我们需要模拟多个不同的用户登录,这是我们就需要进行参数化.这里我们选择比较常用的参数化方法-CSV Data Set Co ...

  5. docker镜像的导入和导出

    启动命令 docker run -d -p 3000:80 twang2218/gitlab-ce-zh:9.0.3 docker run -d -p 8080:80 gitlab/gitlab-ce ...

  6. jquery中stop停止动画笔记

    jQuery stop() 方法用于停止动画或效果,在它们完成之前. stop() 方法适用于所有 jQuery 效果函数,包括滑动.淡入淡出和自定义动画. 语法: $(selector).stop( ...

  7. 把ASM下的HDD VM转换成ARM下Managed Disk的SSD VM

    在ASM下,要把HDD的VM转换成SSD的VM步骤非常复杂.需要手工把Disk从普通存储账户复制到高级存储账户.再通过这个Disk创建VM. 目前在有了ASM到ARM的迁移工具,以及Managed D ...

  8. vim修行

    查用的vim 操作 1.移动光标的方法 h 戒 向左箭央键(←) 光标向左移劢一个字符 j 戒 向下箭央键(↓) 光标向下移劢一个字符 k 戒 向上箭央键(↑) 光标向上移劢一个字符 l 戒 向右箭央 ...

  9. 西安电子科技大学第16届程序设计竞赛 B Words Game

    链接:https://www.nowcoder.com/acm/contest/107/B来源:牛客网 Words Game 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 13107 ...

  10. 基于mjpg-streamer网络视频服务器移植

    MJPG简介: MJPG是MJPEG的缩写,但是MJPEG还可以表示文件格式扩展名. MJPEG 全名为 "Motion Joint Photographic Experts Group&q ...