概述

JavaScript中getElementsByClassName()方法IE8及以下不支持。本文通过使用正则表达式实

现1个兼容方案。

本文内容分为3个部分。

  • 浏览器原生getElementsByClassName()功能和用法。
  • 兼容方案用到的正则表达式理解。
  • 完整代码示例。

大家不用一听到正则表达式就慌,本方案用到的正则表达式并不复杂,而且我也会详细解释的。

原生getElementsByClassName

语法

var elements = document.getElementsByClassName(names);
var elements = rootElement.getElementsByClassName(names);
  • names可以是多个类名,用空格分开。
  • 返回值elements是一个元素数组。
  • 若果用rootElement调用,则只在该元素下搜索。

示例

// 返回所有类名是test的元素
document.getElementsByClassName('test'); // 返回所有同时具有red和test类的元素
document.getElementsByClassName('red test'); // 在id为main这个元素里,拿出所有具有类名test的元素
document.getElementById('main').getElementsByClassName('test'); // 直接拿到类名为test的第一个元素
var testTarget = document.getElementsByClassName("test")[0];

正则表达式简要分析

实现兼容方案的整体思路是:使用getElementsByTagName("*")全部元素,然后循环遍历把这些

元素的类名都拿出来,拿出这些类名之后,最关键的问题就是判断,这些类名是不是符合我要查询的

类名,这就要用到正则表达式来比较,请看下面的代码:

function getElementsByClassName(names, rootElement) {
if (!rootElement) {
rootElement = document;
} var classElements = [];
var allElements = rootElement.getElementsByTagName("*");
// (^|\s)names(\s|$)
pattern = new RegExp("(^|\\s)" + names + "(\\s|$)"); for (var i = 0, j = 0; i < allElements.length; i++) {
if (pattern.test(allElements[i].className)) {
console.log(allElements[i]);
classElements[j] = allElements[i];
j++;
}
} return classElements;
}

上面的代码最难理解的就是正则表达式部分。首先,我默认你已经有一点点正则表达式基础,如果听

都没听过正则表达式,可以考虑看看我写的这篇正则表达式 - JavaScript描述

http://www.cnblogs.com/asheng2016/p/7401391.html

OK,首先我们梳理一下代码逻辑,看看我们需要什么样的正则表达式。假设我们要查找的类名有下面

这几种情况:"ab", "ab cd", "ab cd ef", "ab cd ef gh"。也就是说,如果我们能找到这个类

并成功匹配,那么这个类要么在开头,要么在中间,要么在末尾,只有这三种情况。

我们使用(^|\s)names(\s|$)这个正则表达式就可以实现对上述三种情况的匹配,其中names

变量就表示类名字符串的所有情况(3种)。该正则表达式的图形化含义如下:

根据图像我们理解该正则表达式,首先中间是已知的类名,这没问题,然后就是这个类名的两边可能

存在的情况,可能是开头+类名+结尾、空格+类名+空格、开头+类名+空格等。

\s 表示匹配类名,并且因为在字符串中\也有转义的功能,所以在new RegExp中写成\\

完整函数及测试

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>getElementsByClassName 兼容</title>
</head>
<body> <p><pre>(^|\s)names(\s|$)</pre></p>
<div class="ab cd">ab cd</div>
<div class="a c">a c</div>
<script> function getElementsByClassName(names, rootElement) {
if (!rootElement) {
rootElement = document;
} if (rootElement.getElementsByClassName) {
// console.log("走的是原生方法");
return rootElement.getElementsByClassName(names);
} // console.log("走的是兼容方案");
var classElements = [];
var allElements = rootElement.getElementsByTagName("*");
pattern = new RegExp("(^|\\s)" + names + "(\\s|$)"); for (var i = 0, j = 0; i < allElements.length; i++) {
if (pattern.test(allElements[i].className)) {
classElements[j] = allElements[i];
j++;
}
} return classElements;
} var mt = getElementsByClassName("ab");
console.log(mt[0].className); // "ab cd" var mt2 = getElementsByClassName("a");
console.log(mt2[0].className); // "a c" var mt3 = getElementsByClassName("ac");
console.log(mt3); // [] // 亲测在IE8下可用
</script>
</body>
</html>

参考链接

http://regexper.com

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions

https://developer.mozilla.org/en-US/docs/Web/API/Document/getElementsByClassName

getElementsByClassName - 兼容详细介绍的更多相关文章

  1. linux配置网卡IP地址命令详细介绍及一些常用网络配置命令

    linux配置网卡IP地址命令详细介绍及一些常用网络配置命令2010-- 个评论 收藏 我要投稿 Linux命令行下配置IP地址不像图形界面下那么方 便,完全需要我们手动配置,下面就给大家介绍几种配置 ...

  2. 【转载】硬盘MBR详细介绍

    原文地址:http://blog.chinaunix.net/uid-15007890-id-106892.html 硬盘MBR详细介绍      硬盘是现在计算机上最常用的存储器之一.我们都知道,计 ...

  3. Android manifest之manifest标签详细介绍

    AndroidManifest详细介绍 本文主要对AndroidManifest.xml文件中各个标签进行说明.索引如下: 概要PART--01 manifest标签PART--02 安全机制和per ...

  4. 详细介绍android rom移植知识普及

    详细介绍android rom移植知识普及 最近接到很多兄弟们的求助,也回答过无数个和下面这个问题类似的问题: 如何编译android 原生代码得到一个rom,然后跑到某某手机上. 鉴于很多兄弟对这块 ...

  5. vue对比其他框架详细介绍

    vue对比其他框架详细介绍 对比其他框架 — Vue.jshttps://cn.vuejs.org/v2/guide/comparison.html React React 和 Vue 有许多相似之处 ...

  6. Oracle11g服务详细介绍

    Oracle11g服务详细介绍及哪些服务是必须开启的? Oracle ORCL VSS Writer Service Oracle卷映射拷贝写入服务,VSS(Volume Shadow Copy Se ...

  7. 详细介绍Redis的几种数据结构以及使用注意事项(转)

    原文:详细介绍Redis的几种数据结构以及使用注意事项 1. Overview 1.1 资料 <The Little Redis Book>,最好的入门小册子,可以先于一切文档之前看,免费 ...

  8. Tkinter 控件详细介绍

    Tkinter 控件详细介绍 1.Button 按钮.类似标签,但提供额外的功能,例如鼠标掠过.按下.释放以及键盘操作/事件 2.Canvas 画布.提供绘图功能(直线.椭圆.多边形.矩形) ;可以包 ...

  9. kvm详细介绍

    KVM详解,太详细太深入了,经典 2016-07-18 19:56:38 分类: 虚拟化 原文地址:KVM详解,太详细太深入了,经典 作者:zzjlzx KVM 介绍(1):简介及安装 http:// ...

随机推荐

  1. H4CK1T CTF 2016 Mexico-Remote pentest writeup

    进去网站之后发现连接都是包含类型的,就能想到文件包含漏洞(话说刚总结过就能遇到这题,也算是复习啦) 这里用php://filter/read=convert.base64-encode/resourc ...

  2. Java设计模式——观察者模式(事件监听)

    最近在看Tomcat和Spring的源码,在启动的时候注册了各种Listener,事件触发的时候就执行,这里就用到了设计模式中的观察者模式. 引-GUI中的事件监听 想想以前在学Java的GUI编程的 ...

  3. hihoCoder #1291 : Building in Sandbox 逆向处理+并查集维护

    /** 题目:#1291 : Building in Sandbox 链接:https://hihocoder.com/problemset/problem/1291 题意:就是一个三维的空间里,按照 ...

  4. sublime3 SublimeREPL python3

    https://blog.csdn.net/lylfv/article/details/81453016

  5. 【转】python处理csv数据

    http://desert3.iteye.com/blog/772246 import csv #从文件读取 reader = csv.reader(file(srcFilePath,'rb')) f ...

  6. linux 知识点拾遗

    文件名称 在 Linux 底下,每个档案或文件夹的文件名称最长能够到达 255 的字符,加上完整路径时,最长可达 4096 个字符; 因为 Linux 在文字接口下的一些指令操作关系,一般来说,您在设 ...

  7. (转)java Exception层次结构详解

    转自:http://www.importnew.com/14688.html 1. JAVA异常层次结构 异常指不期而至的各种状况,如:文件找不到.网络连接失败.非法参数等.异常是一个事件,它发生在程 ...

  8. Java并发框架——AQS之怎样使用AQS构建同步器

    AQS的设计思想是通过继承的方式提供一个模板让大家能够非常easy依据不同场景实现一个富有个性化的同步器.同步器的核心是要管理一个共享状态,通过对状态的控制即能够实现不同的锁机制. AQS的设计必须考 ...

  9. html input size maxlength

    最近做项目用到input的size和maxlength属性,以前只顾用没有用心去看看这2个标签的区别,今天周末baidu了一下,有所理解.特记录于此!   <p>Name: <inp ...

  10. linux连接mysql命令

    连接MYSQL: 格式: mysql -h主机地址 -u用户名 -p用户密码 1.例1:连接到本机上的MYSQL 找到mysql的安装目录,一般可以直接键入命令mysql -uroot -p,回车后提 ...