《DOM编程艺术》课堂交流区问题汇总(一)

本课程为网易云课堂 - - 前端开发工程师 - - 《DOM编程艺术》学习总结

问题一:实现浏览器兼容版的element.children

element.children能够获取元素的元素子节点,但是低版本的ie不支持,如何在低版本的ie上兼容类似的功能。

分析解答:

思路:

  • 写一个函数getElementChild(element),传入一个父节点element.

  • 判断DOM中element对象的children属性是否存在,存在则直接返回element.children,不存在则执行兼容代码.

  • 兼容代码思路:

    • 创建一个数组elementArr以便返回最终 [符合要求] 的子节点集合。
    • 调用element对象的childNodes属性,以获取其子节点集合。
    • 遍历子节点集合,对每一个子节点进行判断,如果节点类型为1(即节点类型为元素节点),则添加到elementArr返回数组中。
    • 返回数组elementArr

解决代码:

// nodeType=1 元素节点 nodeType=2 属性节点 nodeType=3 文本节点
function getElementChild(element){
    if (!element.children) {  //如果没有children方法
          var result_elementchild = [],    //新的元素子节点数组
          nodelist = element.childNodes;    //获取所有子节点
          for (var i = 0; i < nodelist.length; i++) {
              if(nodelist[i].nodeType == 1){        //判断节点是否为元素节点
                  result_elementchild.push(nodelist[i]);
                   }
               }
              return result_elementchild;
            } else {
              return element.children;
            }
}

问题二:实现浏览器兼容版的element.dataset

element.dataset能够获取元素的自定义属性,但是低版本的ie不支持,如何在低版本的ie上兼容类似的功能。

相关文章推荐:

分析解答:

思路:

  1. 找到元素中以data-开头的属性名,取到其名称。

  2. 根据dataset的驼峰命名,将data-后面的名称以驼峰命名的方式得到对应的ID名称。

  3. 构建ID名称和属性名称的键值对。

  4. 使用var attribute = element.getAttribute(attributeName)方法,从键值对中找到ID对应的属性名作为attributeName得到其对应的属性值,然后赋值给对应的ID元素。

解答:

        function $(id){  
            return document.getElementById(id);  
        }  
        //正则表达式变换首字母大写  
         function replaceReg(str){   
               var reg = /\b(\w)|\s(\w)/g;   
               str = str.toLowerCase();   
               return str.replace(reg,function(m){return m.toUpperCase()})   
         }  
        //带兼容的函数  
        function get_dataset(ele){  
            if(ele.dataset)  
                return ele.dataset;  
            else{  
            //一下是兼容代码  
                var dataset = {};  
                var ele_split = ele.outerHTML.split(" ");  
                for(var i = 0,element; i < ele_split.length; i++)      
                {  
                    element = ele_split[i];  
                    if (element.substring(0,4) == "data") {   
                        if (element.indexOf(">") !=  -1) {   
                            element = element.split(">")[0];  
                        };  
                        ele_key=element.split("=")[0].slice(5);  
                        ele_value=element.split("=")[1].slice(1,-1);  
                        if(ele_key.indexOf("-") ==  -1){  
                            dataset[ele_key] = ele_value;  
                        }else{  
                            ele_keys=ele_key.split("-");  
                            ele_key=ele_keys[0];  
                            for(i=1;i<ele_keys.length;i++){  
                                ele_key+=replaceReg(ele_keys[i]);  
                            }                 
                        }  
                    };  
                }  
                return dataset;  
            }  

        }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值