zoukankan      html  css  js  c++  java
  • IE不兼容document.getElementsByClassName

    在DOM3里已经加入了getElementsByClassName这个方法,然而IE9、10以外的其它版本均不支持,这是一块伤痛啊!

    目前可以这么解决,判断浏览器支不支持这个方法,如果支持就不管;如果不支持,就在document对象里加入getElementsByClassName这个方法,这样的写法有一个好处,即不管有没有原生函数你都不用去修改代码。

    网上部分人直接定义一个getElementsByClassName函数,但是这样的话就需要把代码中所有使用document.getElementsByClassName改写成getElementsByClassName。多少有点不方便,也不通用。

    下面的方法完美支持了document写法:

     1 if(!document.getElementsByClassName){
     2     document.getElementsByClassName = function(className, element){
     3         var children = (element || document).getElementsByTagName('*');
     4         var elements = new Array();
     5         for (var i=0; i<children.length; i++){
     6             var child = children[i];
     7             var classNames = child.className.split(' ');
     8             for (var j=0; j<classNames.length; j++){
     9                 if (classNames[j] == className){ 
    10                     elements.push(child);
    11                     break;
    12                 }
    13             }
    14         } 
    15         return elements;
    16     };
    17 }
  • 相关阅读:
    webpack—从零开始配置
    多媒体标签 API(video、audio)
    node 爬虫
    node 操作数据库
    es6+
    UI 组件库 引入使用的问题
    单页应用存在 的问题
    ajax 封装(集中 认证、错误、请求loading处理)
    moment.js 时间库
    文件上传大小被限制的解决方案。
  • 原文地址:https://www.cnblogs.com/DreamDrive/p/5961958.html
Copyright © 2011-2022 走看看