文档章节

getElementsByClassName

w
 wangwenya
发布于 2014/06/24 10:12
字数 196
阅读 77
收藏 0

var getElementsByClassName = function (className, tag, elm){

  if (document.getElementsByClassName) {

  getElementsByClassName = function (className, tag, elm) {

  elm = elm || document;

  var elements = elm.getElementsByClassName(className),

  nodeName = (tag)? new RegExp("\\b" + tag + "\\b", "i") : null,

  returnElements = [], current;

  for(var i=0, il=elements.length; i

  current = elements[i];

  if(!nodeName || nodeName.test(current.nodeName)) {

  returnElements.push(current);}}

  return returnElements;};}

  else if (document.evaluate) {getElementsByClassName = function (className, tag, elm) {

  tag = tag || "*";elm = elm || document;var classes = className.split(" "),classesToCheck = "",

  xhtmlNamespace = "http://www.w3.org/1999/xhtml",

  namespaceResolver = (document.documentElement.namespaceURI === xhtmlNamespace)? xhtmlNamespace : null,

  returnElements = [],elements,node;

  for(var j=0, jl=classes.length; j

  classesToCheck += "[contains(concat( , @class , ), " + classes[j] + " )]";

  }try {elements = document.evaluate(".//" + tag + classesToCheck, elm, namespaceResolver, 0, null);

  }catch (e) {elements = document.evaluate(".//" + tag + classesToCheck, elm, null, 0, null);}

  while ((node = elements.iterateNext())) {

  returnElements.push(node);}return returnElements;};}

  else {getElementsByClassName = function (className, tag, elm) {

  tag = tag || "*";elm = elm || document;var classes = className.split(" "),classesToCheck = [],

  elements = (tag === "*" && elm.all)? elm.all : elm.getElementsByTagName(tag),current,returnElements = [],match;

  for(var k=0, kl=classes.length; k<KL; k+="1){classesToCheck.push(new" regexp(?(^|\\s)?="" classes[k]="" +="" ?(\\s|$)?));}<="" p="">

  for(var l=0, ll=elements.length; l

  for(var m=0, ml=classesToCheck.length; m

  match = classesToCheck[m].test(current.className);

  if (!match) {break;}}

  if (match) {returnElements.push(current); }}return returnElements;};}

  return getElementsByClassName(className, tag, elm);};

© 著作权归作者所有

共有 人打赏支持
w
粉丝 3
博文 94
码字总数 33768
作品 0
广州
事件监听一直报错Cannot set property 'display' of undefined

css ↓ .wechatBtn {position: relative;} .wechat {position: absolute; top: 24px; right: -1px; display: none;} js ↓ function wechatBlock (){ var wechat = document.getElementsByCl......

皇上洗碗
2016/09/30
332
0
这样为什么不能起作用?

失意的黑荆棘
2015/10/23
84
2
Html Dom getElementsByClassName

getElementsByClassName() 查找带有相同类名的所有 HTML 元素。该方法返回一个集合。注意不是数组,虽然也可以使用 [index] 方式得到其中的元素。 该集合的常用属性和方法 注意:当集合中的元...

隋茂华
2014/09/29
0
0
使用javascript通过className来获取元素

开始慢慢从JQUERY再转回到纯JS。。。 代码 //原理: 用document.getElementsByTagName('*');来获取所有元素,然后取得相同Class的元素。 function getElementsByClassName(n) { var classEl...

niunan
2010/06/19
0
0
js document.getElementsByClassName的使用介绍与自定义函数

今天在增加一个功能的时候需要用到getElementsByClassName(),getElementsByClassName但是HTML5 新增的DOM API。IE8以下不支持,那么就需要下面的方法解决了 getElementsByClassName()是HTM...

crackernet
06/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Windows 下双 Python 开发环境配置

Windows 下双 Python 开发环境配置作者:老农民(刘启华)QQ: 46715422Email: 46715422@qq.com微信: 46715422 本人曾经在 Windows 下被两个版本环境折腾够呛,现在总结两个 Python...

新疆老农民
昨天
1
0
CentOS7全局安装composer

1. 下载composer-setup.php到当前目录 php -r "copy('https://install.phpcomposer.com/installer', 'composer-setup.php');" 2. 安装 php composer-setup.php 3. 将composer设置成全局 mv c......

月夜中徘徊
昨天
1
0
20180920上课截图

小丑鱼00
昨天
1
0
基于TCP的远程服务调用

前言 上篇,分析了基于HTTP方式的RPC调用。本篇将在上篇的基础上,分析基于TCP方式的RPC调用。代码的整体思路是一致的,可以看作是在上篇功能上的扩展——即通信的方式。 代码:https://git...

MarvelCode
昨天
2
0
67:shell脚本介绍 | shell脚本结构 | 执行data命令用法 | shell脚本中变量

1、shell脚本介绍: shell是一种脚本语言和传统的开发语言相比,会比较简单: shell有自己语法,可以支持逻辑判断、循环等语法: 可以自定义函数,目的是减少重复的代码: shell是系统命令的集合...

芬野de博客
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部