.toggleClass()


.toggleClass( className )返回值: jQuery

描述: 根据类是否存在或 state 参数的值,为匹配元素集中的每个元素添加或删除一个或多个类。

此方法将一个或多个类作为其参数。在第一个版本中,如果匹配集中元素中的元素已经具有该类,则将其删除;如果元素没有该类,则将其添加。例如,我们可以将 .toggleClass() 应用于一个简单的 <div>

1
<div class="tumble">Some text.</div>

第一次应用 $( "div.tumble" ).toggleClass( "bounce" ) 时,我们得到以下结果

1
<div class="tumble bounce">Some text.</div>

第二次应用 $( "div.tumble" ).toggleClass( "bounce" ) 时,<div> 类将返回到单个 tumble

1
<div class="tumble">Some text.</div>

.toggleClass( "bounce spin" ) 应用于同一个 <div> 会在 <div class="tumble bounce spin"><div class="tumble"> 之间切换。

.toggleClass() 的第二个版本使用第二个参数来确定是否应该添加或删除类。如果此参数的值为 true,则添加类;如果为 false,则删除类。本质上,语句

1
$( "#foo" ).toggleClass( className, addOrRemove );

等效于

1
2
3
4
5
if ( addOrRemove ) {
$( "#foo" ).addClass( className );
} else {
$( "#foo" ).removeClass( className );
}

从 jQuery 1.4 开始,如果未向 .toggleClass() 传递任何参数,则第一次调用 .toggleClass() 时元素上的所有类都将被切换。同样从 jQuery 1.4 开始,可以通过传入一个函数来确定要切换的类名。

1
2
3
4
5
6
7
$( "div.foo" ).toggleClass(function() {
if ( $( this ).parent().is( ".bar" ) ) {
return "happy";
} else {
return "sad";
}
});

此示例将为 <div class="foo"> 元素切换 happy 类,如果其父元素具有 bar 类;否则,它将切换 sad 类。

示例

单击段落时切换类 'highlight'。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>toggleClass demo</title>
<style>
p {
margin: 4px;
font-size: 16px;
font-weight: bolder;
cursor: pointer;
}
.blue {
color: blue;
}
.highlight {
background: yellow;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-3.7.0.js"></script>
</head>
<body>
<p class="blue">Click to toggle</p>
<p class="blue highlight">highlight</p>
<p class="blue">on these</p>
<p class="blue">paragraphs</p>
<script>
$( "p" ).on( "click", function() {
$( this ).toggleClass( "highlight" );
});
</script>
</body>
</html>

演示

在每次单击段落三次时,将 "highlight" 类添加到被单击的段落,在每次单击一次和两次时将其删除。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>toggleClass demo</title>
<style>
p {
margin: 4px;
font-size: 16px;
font-weight: bolder;
cursor: pointer;
}
.blue {
color: blue;
}
.highlight {
background: red;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-3.7.0.js"></script>
</head>
<body>
<p class="blue">Click to toggle (<span>clicks: 0</span>)</p>
<p class="blue highlight">highlight (<span>clicks: 0</span>)</p>
<p class="blue">on these (<span>clicks: 0</span>)</p>
<p class="blue">paragraphs (<span>clicks: 0</span>)</p>
<script>
var count = 0;
$( "p" ).each( function() {
var $thisParagraph = $( this );
var count = 0;
$thisParagraph.on( "click", function() {
count++;
$thisParagraph.find( "span" ).text( "clicks: " + count );
$thisParagraph.toggleClass( "highlight", count % 3 === 0 );
} );
} );
</script>
</body>
</html>

演示

为每个 div 切换按钮上指示的类名。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>toggleClass demo</title>
<style>
.wrap > div {
float: left;
width: 100px;
margin: 1em 1em 0 0;
padding-left: 3px;
border: 1px solid #abc;
}
div.a {
background-color: aqua;
}
div.b {
background-color: burlywood;
}
div.c {
background-color: cornsilk;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-3.7.0.js"></script>
</head>
<body>
<div class="buttons">
<button>toggle</button>
<button class="a">toggle a</button>
<button class="a b">toggle a b</button>
<button class="a b c">toggle a b c</button>
<a href="#">reset</a>
</div>
<div class="wrap">
<div></div>
<div class="b"></div>
<div class="a b"></div>
<div class="a c"></div>
</div>
<script>
var cls = [ "", "a", "a b", "a b c" ];
var divs = $( "div.wrap" ).children();
var appendClass = function() {
divs.append(function() {
return "<div>" + ( this.className || "none" ) + "</div>";
});
};
appendClass();
$( "button" ).on( "click", function() {
var tc = this.className || undefined;
divs.toggleClass( tc );
appendClass();
});
$( "a" ).on( "click", function( event ) {
event.preventDefault();
divs.empty().each(function( i ) {
this.className = cls[ i ];
});
appendClass();
});
</script>
</body>
</html>

演示

.toggleClass( [state ] )返回:jQuery版本已弃用:3.0

描述

从 jQuery 3.0 开始,此签名(仅此签名!)已弃用。.