热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Safari浏览器不支持element.querySelectorquerySelectorAll这两个原生的dom选择器?

document.querySelector可以运行element.querySelector会提示undefiendfunctionquerySelecotr你们有遇

document.querySelector可以运行
element.querySelector 会提示"undefiend function querySelecotr"
你们有遇到这个问题吗?


代码如下,是在mac OSX 10.10.5 safari 9.1.1 下运行这段JS。

1
2
3
4
5
6
7
8
9
10
var

   dealers = TOOLKIT.objectToArray(document.querySelector('.order-panel').querySelectorAll('.panel-default')),//这里正常,因为dom对象是document

   avaliable_dealers = dealers.filter(function(dealer_item){

       var

          js_product = TOOLKIT.objectToArray(dealer_item.querySelectorAll('.js_product'));

       return js_product.some(function(js_product_item){

           return js_product_item.querySelector('.js_checkbox').checked;

       });

   });

 ....

TOOLKIT.objectTOArray是将dom对象强制转换成数组的一个方法,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
    TOOLKIT.objectToArray = function(obj){

        var

            arr = [],

            index,

            type = typeof(obj);

        if(type == 'object' && !Array.isArray(obj)){

            for(index in obj){

                if(obj.hasOwnProperty(index)){

                    arr.push(obj[index])

                }

            }

        }



推荐阅读
author-avatar
权利阳成_278
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有