css - JavaScript getElementsByClassName方法求解
天蓬老师
天蓬老师 2017-04-11 12:46:56
[JavaScript讨论组]
function getElementsByClassName(node,classname){
if(node.getElementsByClassName){
return node.getElementsByClassName(**classname**);
} else {
var results=new Array();
var elems=node.getElementsByTagName("*");
for(var i=0; i
天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(5)
PHP中文网

低版本的ie浏览器不支持getElementsByClassName方法,上面那段代码是封装了一个兼容性良好的getElementsByClassName,各个浏览器版本都可以使用。
比如说你要在整个页面中获取元素,第一个参数就是document ,第二个参数是你想要获取的元素的classname 。
比如说你要在ul中获取元素,第一个参数就是对ul的引用,这个引用可以通过其他方法例如getElementById或者getElementsByTagName 来得到,第二个参数同上

怪我咯

因为那是个形参呀,你要使用这个函数时,将字符串(类名)作为第二个参数传递过去即可。

ringa_lee

这个写法有bug,建议第八行改成

if(elems[i].className.indexOf(" "+classname+" ") !=-1) {


这样就不会在找类名为'p'的时候也匹配到类名'p123','123p','1p23'之类的

高洛峰

为什么是*,代表什么意思

PHP中文网

用document.querySelector()方法更方便吧,不过ie6和ie7不兼容好像

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号