以前我们有需要用js或jquery的一些方法hasClass、addClass、removeClass,在一个元素的class属性上添加或者删除某几个类,达到某种样式变化的需求,但还是稍微麻烦了一些。
h5新增的classList可以让我们更方便的元素的类名进行操作。
注意
classList兼容性有些差,不兼容ie10以下的ie浏览器。
示例
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
|
<!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 > |
新增类
使用add方法,你可以往页面元素是新增一个或多个类:
1
|
document.getElementById( "myDIV" ).classList.add( "mystyle" ); |
删除一个类
使用remove方法,你可以删除单个CSS类:
1
|
document.getElementById( "myDIV" ).classList.remove( "mystyle" ); |
在元素中切换类名
在元素中切换类名。使用toggle方法,语法:toggle(class, true|false)
第一个参数为要在元素中移除的类名,并返回 false。
如果该类名不存在则会在元素中添加类名,并返回 true。
第二个是可选参数,设置布尔值用于设置元素是否强制添加或移除类,不管该类名是否存在。例如:
移除一个
1
|
document.getElementById( "myDIV" ).classList.toggle( "classToRemove" , false ); |
添加一个
1
|
document.getElementById( "myDIV" ).classList.toggle( "classToAdd" , true ); |
注意: Internet Explorer 或 Opera 12 及其更早版本不支持第二个参数
检查是否含有某个类
使用contains方法,判断某个类是否存在,返回布尔值。
1
2
|
//returns true or false document.getElementById( "myDIV" ).classList.contains( "myDIV" ); |
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容