js 选择器

Posted 淡然_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 选择器相关的知识,希望对你有一定的参考价值。

var queryEle = function(selector){
        var selectReg = /^(#)?(\.)?(\w+)$/img;
        var result = selectReg.exec(selector),
            data = [];
        //id
        if(result[1]){
            if(result[3]){
                if(typeof document.querySelector==‘function‘){
                    return document.querySelector(result[1]+result[3]);
                }else{
                    return document.getElementById(result[3]);
                }
            }
        }else
        //class
        if(result[2]){
            if(result[3]){
                if(typeof document.getElementsByClassName==‘function‘){
                    var dom = document.getElementsByClassName(result[3]);
                    if(dom){
                        return converArr(dom);
                    }
                }else{
                    var dom2 = document.getElementsByTagName(‘*‘);
                    for(var i=0;i<dom2.length;i++){
                        if(dom2[i].className.test(new RegExp(result[2]))){
                            data.push(dom2[i]);
                        }
                    }
                }
                return data;
            }
        }else
        if(result[3]) {
            var doms = document.getElementsByTagName(result[3].toLowerCase());
            if(doms) {
                result = converArr(doms);
            }
        }
        return result;

    };
    function converArr(dom){
        var arr = null;
        try{
           arr = Array.prototype.slice.call(dom,0);
        }catch(e){
            for(var i=0;i<dom.length;i++){
                arr.push(dom[i]);
            }
        }
        return arr;
    }

    console.log(queryEle(‘.left‘));

  

以上是关于js 选择器的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段6——CSS选择器

前端开发中最常用的JS代码片段

THREE.js - 大型int作为Uniform

Android - 片段中的联系人选择器

日期选择器对话框在片段中不起作用[关闭]

在标签片段android中添加谷歌地点选择器