使用HTML5的classList属性操做CSS类

前言

之前咱们有须要用js或jquery的一些方法hasClass、addClass、removeClass,在一个元素的class属性上添加或者删除某几个类,达到某种样式变化的需求,但仍是稍微麻烦了一些。
h5新增的classList能够让咱们更方便的元素的类名进行操做。html

注意

classList兼容性有些差,不兼容ie10如下的ie浏览器。jquery

示例

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>classList</title>
    <style>
        .mystyle {
            width: 300px;
            height: 50px;
            background-color: red;
            color: white;
            font-size: 25px;
        }
    </style>
</head>
<body>

<p>点击按钮为DIV元素添加 "mystyle" 类。</p>
<button onclick="myFunction()">点我</button>
<div id="myDIV">
    我是一个 DIV 元素。
</div>
<script>
    function myFunction() {
        document.getElementById("myDIV").classList.add("mystyle");
    }
</script>

</body>
</html>

clipboard.png

新增类

使用add方法,你能够往页面元素是新增一个或多个类:浏览器

document.getElementById("myDIV").classList.add("mystyle");

删除一个类

使用remove方法,你能够删除单个CSS类:spa

document.getElementById("myDIV").classList.remove("mystyle");

在元素中切换类名

在元素中切换类名。使用toggle方法,语法:toggle(class, true|false)
第一个参数为要在元素中移除的类名,并返回 false。
若是该类名不存在则会在元素中添加类名,并返回 true。 code

第二个是可选参数,设置布尔值用于设置元素是否强制添加或移除类,无论该类名是否存在。例如:htm

移除一个ip

document.getElementById("myDIV").classList.toggle("classToRemove", false);

添加一个utf-8

document.getElementById("myDIV").classList.toggle("classToAdd", true);

注意: Internet Explorer 或 Opera 12 及其更早版本不支持第二个参数rem

检查是否含有某个类

使用contains方法,判断某个类是否存在,返回布尔值。get

//returns true or false
 document.getElementById("myDIV").classList.contains("myDIV");
相关文章
相关标签/搜索