javascript getElementsByClassName函数


Posted in Javascript onApril 01, 2010

今天在网上看到的一个根据ClassName获取Elements的脚本,在此记录一下,以便日后使用。

var getElementsByClassName = function(searchClass, node, tag) { 
if (document.getElementsByClassName) { 
return document.getElementsByClassName(searchClass) 
} else { 
node = node || document; 
tag = tag || "*"; 
var classes = searchClass.split(" "), 
elements = (tag === "*" && node.all) ? node.all : node.getElementsByTagName(tag), 
patterns = [], 
returnElements = [], 
current, 
match; 
var i = classes.length; 
while (--i >= 0) { 
patterns.push(new RegExp("(^|\\s)" + classes[i] + "(\\s|$)")); 
} 
var j = elements.length; 
while (--j >= 0) { 
current = elements[j]; 
match = false; 
for (var k = 0, kl = patterns.length; k < kl; k++) { 
match = patterns[k].test(current.className); 
if (!match) break; 
} 
if (match) returnElements.push(current); 
} 
return returnElements; 
} 
}

下面是网上其它的一些相关介绍,大家可以一起参考下。

DOM中的getElementsByClassName解释如下:DOM API 中提供3种方法取元素(getElementById,getElementsByName,getElementsByTagName),经常编写CSS的人自然就会产生疑问,有没有根据样式类名取元素的方法,可惜,DOM1/2 里面都没有这样的方法,prototype 很早就扩展过DOM的方法,添加了 getElementsByClassName,从方法名上看,似乎非常正统,与前面3种方法名称也像,分析其代码,却发现还是通过 getElementsByTagName 来实现。这个方法称不上优雅,因为需要遍历所有的元素,探测元素是否包含目标样式类名,返回符合条件的元素数组。google了一下,却没有找到更优雅高效的替代方法。

function getElementsByClassName(className, parentElement){ 
var elems = ($(parentElement)||document.body).getElementsByTagName("*"); 
var result=[]; 
for (i=0; j=elems[i]; i++){ 
if ((" "+j.className+" ").indexOf(" "+className+" ")!=-1){ 
result.push(j); 
} 
} 
return result; 
}

既然有getElementsByClassName,一样可以有 getElementsByAttribute(如:getElementsByValue、getElementsByStyle、getElementsByType)
document.getElementsByClassName = function(className,oBox) { 
//适用于获取某个HTML区块内部含有某一特定className的所有HTML元素 
this.d= oBox || document; 
var children = this.d.getElementsByTagName('*') || document.all; 
var elements = new Array(); 
for (var ii = 0; ii < children.length; ii++) { 
var child = children[ii]; 
var classNames = child.className.split(' '); 
for (var j = 0; j < classNames.length; j++) { 
if (classNames[j] == className) { 
elements.push(child); 
break; 
} 
} 
} 
return elements; 
} document.getElementsByType = function(sTypeValue,oBox) { 
//适用于获取某个HTML区块内部同属于某一特定type的所有HTML元素,如:input,script,link等等 
this.d= oBox || document; 
var children = this.d.getElementsByTagName('*') || document.all; 
var elements = new Array(); 
for (var ii = 0; ii < children.length; ii++) { 
if (children[ii].type == sTypeValue) { 
elements.push(children[ii]); 
} 
} 
return elements; 
} 
function $() { 
var elements = new Array(); 
for (var ii = 0; ii < arguments.length; ii++) { 
var element = arguments[ii]; 
if (typeof element == 'string') 
element = document.getElementById(element); 
if (arguments.length == 1) 
return element; 
elements.push(element); 
} 
return elements; 
} 
$Cls = function (s,o){ 
return document.getElementsByClassName(s,o); 
}; 
$Type = function (s,o){ 
return document.getElementsByType(s,o); 
}; 
$Tag = function (s,o){ 
this.d=o || document; 
return this.d.getElementsByTagName(s); 
}; 
$Name = function (s){ //通过name的方式只能针对整个document而言,不能为其限定范围 
return document.getElementsByName(s); 
};
Javascript 相关文章推荐
Javascript YUI 读码日记之 YAHOO.util.Dom - Part.2 0
Mar 22 Javascript
Extjs NumberField后面加单位实现思路
Jul 30 Javascript
jquery中ready()函数执行的时机和window的load事件比较
Jun 22 Javascript
javascript创建函数的20种方式汇总
Jun 23 Javascript
js实现跨域的4种实用方法原理分析
Oct 29 Javascript
15个常用的jquery代码片段
Dec 19 Javascript
Vue.js实现一个自定义分页组件vue-paginaiton
Sep 05 Javascript
Vue入门学习笔记【基本概念、对象、过滤器、指令等】
Apr 13 Javascript
vue+django实现一对一聊天功能的实例代码
Jul 17 Javascript
selenium+java中用js来完成日期的修改
Oct 31 Javascript
Vue中使用better-scroll实现轮播图组件
Mar 07 Javascript
JavaScript实现单点登录的示例
Sep 23 Javascript
JS getStyle获取最终样式函数代码
Apr 01 #Javascript
Javascript 通过json自动生成Dom的代码
Apr 01 #Javascript
JS中confirm,alert,prompt函数使用区别分析
Apr 01 #Javascript
JavaScript中实现块作用域的方法
Apr 01 #Javascript
cloudgamer出品ImageZoom 图片放大效果
Apr 01 #Javascript
js 异步处理进度条
Apr 01 #Javascript
JavaScript中String和StringBuffer的速度之争
Apr 01 #Javascript
You might like
PHP 加密/解密函数 dencrypt(动态密文,带压缩功能,支持中文)
2009/01/30 PHP
php 变量定义方法
2009/06/14 PHP
PHP如何读取由JavaScript设置的Cookie
2017/03/22 PHP
jquery.alert 弹出式复选框实现代码
2009/06/15 Javascript
TimergliderJS 一个基于jQuery的时间轴插件
2011/12/07 Javascript
js给onclick事件赋值,动态传参数实例解说
2013/03/28 Javascript
推荐8款jQuery轻量级树形Tree插件
2014/11/12 Javascript
JavaScript实现控制打开文件另存为对话框的方法
2015/04/17 Javascript
JavaScript数组迭代器实例分析
2015/06/09 Javascript
浅析JavaScript中的对象类型Object
2016/05/26 Javascript
基于JavaScript实现图片剪切效果
2017/03/07 Javascript
jQuery插件FusionCharts实现的MSBar3D图效果示例【附demo源码】
2017/03/23 jQuery
vue脚手架vue-cli的学习使用教程
2017/06/06 Javascript
微信小程序动态显示项目倒计时效果
2017/06/13 Javascript
微信页面弹出键盘后iframe内容变空白的解决方案
2017/09/20 Javascript
详细分析单线程JS执行问题
2017/11/22 Javascript
vue 详情跳转至列表页实现列表页缓存
2019/03/27 Javascript
JQuery特殊效果和链式调用操作示例
2019/05/13 jQuery
vue中使用GraphQL的实例代码
2019/11/04 Javascript
JavaScript this使用方法图解
2020/02/04 Javascript
Vue 中使用 typescript的方法详解
2020/02/17 Javascript
基于JS实现快速读取TXT文件
2020/08/25 Javascript
Python网络爬虫中的同步与异步示例详解
2018/02/03 Python
PyQt5响应回车事件的方法
2019/06/25 Python
如何实现Django Rest framework版本控制
2019/07/25 Python
python文件排序的方法总结
2020/09/13 Python
五种Python转义表示法
2020/11/27 Python
基于MUI框架使用HTML5实现的二维码扫描功能
2018/03/01 HTML / CSS
2019史上最全Database工程师题库
2015/12/06 面试题
女儿十岁生日答谢词
2014/01/27 职场文书
校园安全检查制度
2014/02/03 职场文书
个人四风问题原因分析及整改措施
2014/09/28 职场文书
2014年村支部书记四风对照检查材料思想汇报
2014/10/02 职场文书
民间借贷借条范本
2015/05/25 职场文书
天气温馨提示语
2015/07/14 职场文书
springboot读取resources下文件的方式详解
2022/06/21 Java/Android