原生js操作元素类名(classList,classList.add...)

1、classList

classList属性是一个只读属性,返回元素的类名,作为一个DOMTokenList集合(用于在元素中添加,移除及切换css类)

length:返回类列表中类的数量,该属性是只读的

<style>

.lis {

width: 200px;

height: 100px;

background-color: skyblue;

}

.box {

width: 100px;

height: 100px;

border: 1px solid #e15671;

}

.red {

background: red;

}

.width {

width: 200px;

}

</style>

<body>

<ul>

<li class="lis red width">111</li>

</ul>

<div class="box"></div>

</body>

<script>

let box = document.querySelector('.box');

let list = box.classList;

console.log(list.length);//1

console.log(list);//DOMTokenList 'box', value: 'box'

let lists = document.querySelector(".lis");

let len = lists.classList;

console.info(len.length);//3

console.info(len);//DOMTokenList(3) 'lis', 'red', 'width', value: 'lis red width'

</script>

2、classList.add(className1,className2...);

添加一个或多个类名,如果指定的类名存在,则不添加

<style>

.mystyle {

width: 300px;

height: 50px;

background-color: skyblue;

color: white;

font-size: 25px;

}

.once{

padding: 20px;

border: 2px solid orange;

}

</style>

<body>

<button οnclick="myFun()">点我</button>

<div id="boss">

我是一个 div

</div>

</body>

<script>

//添加一个类样式

function myFun() {

let divCla = document.getElementById("boss");

let style = divCla.classList.add("mystyle");

}

//添加两个及两个以上类样式 类名用逗号','隔开

function myFun() {

let divCla = document.getElementById("boss");

let style = divCla.classList.add("mystyle","once");

}

</script>

3、classList.contains(className);

判断指定的类名是否存在,返回布尔值(true:存在;false:不存在)

<style>

.lis {

width: 200px;

height: 100px;

background-color: skyblue;

}

.red {

background: red;

}

.width {

width: 200px;

}

</style>

<body>

<ul>

<li class="lis red width">111</li>

</ul>

</body>

<script>

let lis = document.getElementsByClassName("lis")0;

let style = lis.classList.contains('red');

console.log(style);//true 存在类名

let style1 = lis.classList.contains('height');

console.log(style1);//false

</script>

4、classList.item(index);

返回索引值对应的类名 索引值在区间范围外 返回null

<style>

.lis {

width: 200px;

height: 100px;

background-color: skyblue;

}

.red {

background: red;

}

.width {

width: 200px;

}

</style>

<body>

<ul>

<li class="lis red width">111</li>

</ul>

</body>

<script>

//第一个类名 根据索引查询

let lis = document.getElementsByClassName("lis")0;

let className = lis.classList.item(0);

console.log(className);//lis

//第二个类名

let className2 = lis.classList.item(1);

console.log(className2);//red

</script>

5、classList.remove(className1,className2...);

移除一个或多个类名 移除不存在的类名,不会报错

<style>

.mystyle {

width: 300px;

height: 50px;

background-color: skyblue;

color: white;

font-size: 25px;

}

.once{

padding: 20px;

border: 2px solid orange;

}

</style>

<body>

<button οnclick="myFun()">点我</button>

<div id="boss" class="mystyle">

我是一个 div

</div>

</body>

<script>

function myFun() {

let box = document.querySelector('#boss');

let list = box.classList.remove("mystyle");

// 移除不存在的类名 不会报错

//let box = document.querySelector('#boss');

//let list = box.classList.remove("once");

}

</script>

6、classList.toggle(className, true \| false);

切换类名;

第一个参数为要移除的类名,并返回false;若该参数不存在则添加类名,返回true

第二个参数为布尔值,设置是否强制添加或移除类,不论类名是否存在

<style>

.mystyle {

width: 300px;

height: 50px;

background-color: skyblue;

color: white;

font-size: 25px;

}

.box {

width: 100px;

height: 100px;

border: 1px solid #e15671;

}

</style>

<body>

<button οnclick="myFun()">点我</button>

<div id="boss" class="mystyle">

我是一个 div

</div>

</body>

<script>

function myFun() {

//添加类名

let box = document.querySelector('#boss');

let list = box.classList.toggle("box");

//给两个值的时候

//移除类名

let removeList = box.classList.toggle('mystyle',false);

//添加类名

let addList = box.classList.toggle('box',true);

}

</script>

7、classList.replace( oldClassName,newClassName );

替换类名,返回布尔值,true表示替换成功

第一个参数为被替换的类名

第二个参数为要替换的新类名

<style>

.mystyle {

width: 300px;

height: 50px;

background-color: skyblue;

color: white;

font-size: 25px;

}

.box {

width: 100px;

height: 100px;

border: 1px solid #e15671;

}

</style>

<body>

<button οnclick="myFun()">点我</button>

<div id="boss" class="mystyle">

我是一个 div

</div>

</body>

<script>

function myFun() {

let box = document.querySelector('#boss');

let replace = box.classList.replace('mystyle','box');

}

</script>

相关推荐
_柳青杨2 小时前
深入理解 JavaScript 事件循环
前端·javascript
大家的林语冰7 小时前
ES5 凉凉,Babel 8 正式发布,默认不再编译为 ES5 和 CJS......
前端·javascript·前端工程化
weedsfly10 小时前
异步编程全景与事件循环——彻底搞懂 JS 执行机制
前端·javascript
用户0595401744610 小时前
AI Agent记忆测试踩坑实录:Mock骗了我一周,Mem0+pytest一招破局
前端·css
用户17335980753710 小时前
纯前端 PDF 数字签名实战:Vue 3 + pdf-lib 在浏览器里完成签名嵌入
前端·javascript
JieE21220 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21221 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
kyriewen1 天前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
Larcher1 天前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
默_笙1 天前
🃏 JS 只有 8 种数据类型,但我花了 2 天才搞懂 null 和 undefined 的区别
javascript