用户登录
用户注册

分享至

使用HTML5里的classList操作CSS类

  • 作者: 梦里的梦想
  • 来源: 51数据库
  • 2021-08-24

在javascript和javascript工具库里征战多年,我经常有这样的遐想:什么时候现代浏览器里能提供一些辅助方法和类库,替代那些javascript工具库,比如jquery,让我们用浏览器原生的方法替代它们。我知道浏览器必定会向这个方向改进,但这个进化过程不会很迅速,而且各种浏览器需要共同做这样的革新,火狐浏览器、谷歌浏览器、特别是ie,只有当这些主流浏览器都具备了这样的功能,我们的愿望才算真正的实现。好消息是,其中有一个这样的功能已经被加入到了html5 api里:classlist

在html5 api里,页面dom里的每个节点上都有一个classlist对象,程序员可以使用里面的方法新增、删除、修改节点上的css类。使用classlist,程序员还可以用它来判断某个节点是否被赋予了某个css类。

element.classlist

这个classlist对象里有很多有用的方法:

xml/html code复制内容到剪贴板
  1. {   
  2.  length: {number}, /* # of class on this element */   
  3.  add: function() { [native code] },   
  4.  contains: function() { [native code] },   
  5.  item: function() { [native code] }, /* by index */   
  6.  remove: function() { [native code] },   
  7.  toggle: function() { [native code] }   
  8. }   
  9.   

正如你上面看到的,element.classlist类很小,但里面的每个方法都很有用。

新增css类

使用add方法,你可以往页面元素是新增一个或多个css类:

mydiv.classlist.add('mycssclass');

删除一个css类

使用remove方法,你可以删除单个css类:

mydiv.classlist.remove('mycssclass');

你可以在这个方法里一次传入多个类名,用空格分开,但执行的结果很有可能不是你预期的。

反转css类的有无

mydiv.classlist.toggle('mycssclass'); //现在是增加
mydiv.classlist.toggle('mycssclass'); //现在是删除

这个方法的作用就是,当mydiv元素上没有这个css类时,它就新增这个css类;如果mydiv元素已经有了这个css类,它就是删除它。就是反转操作。

检查是否含有某个css类

mydiv.classlist.contains('mycssclass'); //returns true or false

目前所有的现代浏览器(火狐浏览器,谷歌浏览器等)都支持这个classlist类,所以,相信新型的javascript类库里都会使用classlist类来操作页面css类,而不需像以前一样去分析元素节点的class属性!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

软件
前端设计
程序设计
Java相关