微学网

热门关键词:   as  thinkphp  ecshop  xxx  php分页  商务通
热门: ASP.NET PHP编程 ASP编程 JSP编程 Python

使用HTML5里的classList操作CSS类

发布时间:2017-05-02 来源:未知 点击:

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

在HTML5 API里,页面DOM里的每个节点上都有一个classList对象,程序员可以使用里面的方法新增、删除、修改节点上的CSS类。使用classList,程序员还可以用它来判断某个节点是否被赋予了某个CSS类。YKXHTML5中文学习网 - HTML5先行者学习网

Element.classListYKXHTML5中文学习网 - HTML5先行者学习网

这个classList对象里有很多有用的方法:YKXHTML5中文学习网 - HTML5先行者学习网

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类很小,但里面的每个方法都很有用。YKXHTML5中文学习网 - HTML5先行者学习网

新增CSS类YKXHTML5中文学习网 - HTML5先行者学习网

使用add方法,你可以往页面元素是新增一个或多个css类:YKXHTML5中文学习网 - HTML5先行者学习网

myDiv.classList.add('myCssClass');YKXHTML5中文学习网 - HTML5先行者学习网

删除一个CSS类YKXHTML5中文学习网 - HTML5先行者学习网

使用remove方法,你可以删除单个CSS类:YKXHTML5中文学习网 - HTML5先行者学习网

myDiv.classList.remove('myCssClass');YKXHTML5中文学习网 - HTML5先行者学习网

你可以在这个方法里一次传入多个类名,用空格分开,但执行的结果很有可能不是你预期的。YKXHTML5中文学习网 - HTML5先行者学习网

反转CSS类的有无YKXHTML5中文学习网 - HTML5先行者学习网

myDiv.classList.toggle('myCssClass'); //现在是增加YKXHTML5中文学习网 - HTML5先行者学习网
myDiv.classList.toggle('myCssClass'); //现在是删除
YKXHTML5中文学习网 - HTML5先行者学习网

这个方法的作用就是,当myDiv元素上没有这个CSS类时,它就新增这个CSS类;如果myDiv元素已经有了这个CSS类,它就是删除它。就是反转操作。YKXHTML5中文学习网 - HTML5先行者学习网

检查是否含有某个CSS类YKXHTML5中文学习网 - HTML5先行者学习网

myDiv.classList.contains('myCssClass'); //returns true or falseYKXHTML5中文学习网 - HTML5先行者学习网

目前所有的现代浏览器(火狐浏览器,谷歌浏览器等)都支持这个classList类,所以,相信新型的javaScript类库里都会使用classList类来操作页面CSS类,而不需像以前一样去分析元素节点的class属性!YKXHTML5中文学习网 - HTML5先行者学习网

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持程序员学习网YKXHTML5中文学习网 - HTML5先行者学习网

您可能感兴趣的文章

网络编程 | 前端制作 | 数据库 | CMS教程 | 脚本编程 | 微信公众号 | 框架 | 小程序 | 服务器 | APP开发 |

凡本网站转载的文章、图片等资料的版权归版权所有人所有,因无法和版权所有者一一联系,如果本网站选取的文/图威胁到您的权益,请您及时和本网站联系。 我们会在第一时间内采取措施,避免给双方造 成不必要的损失。
© 2015-2018 微学网 版权所有,并保留所有权利。 备案号:粤ICP备09051474号-1

电脑版 | 移动版