`
shizisongsong
  • 浏览: 39396 次
文章分类
社区版块
存档分类
最新评论

原生的html元素选择器的实现,类似jquery选择器

阅读更多

做前端,需要选择元素,虽说有jquery和各大js库已经帮我造好了轮子,但我想试试自己实现一个,正好项目也不忙,正好加入自己的js文件中,下面是实现代码。用$g(“#content .op”)这种格式就可以调用,和jquery $()的参数一样: 可以500%提高开发效率的前端UI框架!  

function $findChilds(parentNode, text) 
{ 
    //如果不传入父节点的话,默认为body 
    if(parentNode == undefined) 
        parentNode = document.body; 
    var childNodes = parentNode.childNodes; 
    var results = []; 
    //子节点大于零才循环 
    if(childNodes.length > 0) 
    { 
        var length = childNodes.length; 
        //循环查找符合text的节点 
        for(var i=0;i<length;++i) 
        { 
            //三种情况,className,id, tagName 
            switch(text.substr(0, 1)) 
            { 
            case '.': 
                //这两种:parentNode.getElementsByClassName,parentNode.all 
//都是后来加上的,如果浏览器这两种方法都不支持,那就只能暴力递归了 
                if(parentNode.getElementsByClassName) 
                    return parentNode.getElementsByClassName(text.substr(1)); 
                else if(parentNode.all) 
                { 
                    var finded = []; 
                    var jlength = parentNode.all.length; 
                    for(var j=0;j<jlength;++j) 
                        if(parentNode.all[j].className == text.substr(1)) 
                            finded.push(parentNode.all[j]); 
                    return finded; 
                } 
                //以上两种方法都不支持,直接判断 
                if(childNodes[i].className == text.substr(1)) 
                    results.push(childNodes[i]); 
                break; 
            case '#': 
                return [document.getElementById(text.substr(1))]; 
            default: 
                return parentNode.getElementsByTagName(text); 
            } 
            //判断完后,把当前子元素的子元素传入$findChilds进行递归查找,返回的结果直接和现在的结果合并 
            results = results.concat($findChilds(childNodes[i], text)); 
        } 
    } 
    return results; 
}   
   
String.prototype.vtrim = function() { 
      return this.replace(/^\s+|\s+$/g, ''); 
}   
   
function $g(text) 
{ 
    //按照空格分割参数 
    var values = text.vtrim().split(" "); 
    var length = values.length; 
    //如果只有一个选择参数的话,就直接调用dom方法返回结果。 
    if(length == 1) 
        switch(values[0].substr(0, 1)) 
        { 
        case "#": 
            return document.getElementById(values[0].substr(1)); 
        case ".": 
            if(document.getElementsByClassName) 
                return document.getElementsByClassName(values[0].substr(1)); 
        default: 
            return document.getElementsByTagName(values[0]); 
        } 
    //每次迭代都会产生许多符合参数的结果节点,这里结果节点的名称为parentNodes,第一次循环默认为body 
    var parentNodes = [document.body]; 
    //外层循环为迭代每个传入的参数 
    for(var i = 0; i < length; ++i) 
    { 
        var jlength = parentNodes.length; 
        var results = []; 
        //这里如果values的长度为零的话, 
        //就说明是多出来的空格, 
        //例如:$g("      .content");这种情况不执行代码直接跳入下一循环 
        var tmpValue = values[i].vtrim(); 
        if(tmpValue.length <= 0) 
            continue; 
        //内层循环为迭代每个结果节点, 
        //在结果节点中查找符合选择条件的结果。当然第一次为body 
        for(var j=0;j<jlength;++j) 
        { 
            //$findChilds就是上边的那个函数,就是选择某个节点的子节点的 
            var result = $findChilds(parentNodes[j], values[i].vtrim()); 
            var rlength = result.length; 
            //因为返回的有时候是html容器,无法直接和数组concat所以倒入数组,这里有优化空间,但暂不考虑性能先这么做 
            for (var k = 0; k < rlength; ++k) 
                results.push(result[k]); 
        } 
        //没有结果,立即返回undefined 
        if(results == undefined || results.length <= 0) 
            return undefined; 
        //最后一次循环就直接返回结果数组,但是如果最后一个选择条件是选择id的话,那就不返回数组直接返回dom对象了 
        if (i == length - 1) 
        { 
            if (values[i].substr(0, 1) == "#") 
                return results[0]; 
            return results; 
        } 
        parentNodes = results; 
    } 
}

 

 

经过在ff ie6下的测试 单纯的选择id比jquery要快很多,
其他的部分选择模式我测试的少数比jquery要快。 可以500%提高开发效率的前端UI框架!   
当然测试不可能全面,还可能会有bug,而且不支持类似于.content:first-child这样的伪类选择。

0
0
分享到:
评论

相关推荐

    基于jquery的H5移动端选择器,日期选择器,自定义级联选择器,自定义html选择器

    最后,将选择器绑定到HTML元素上,即可在页面上看到效果。同时,阅读库的文档将有助于理解其具体用法和API,以便更好地定制和控制选择器的行为。 总的来说,基于jQuery的H5移动端选择器是现代Web开发中不可或缺的一...

    原生的html元素选择器类似jquery选择器

    本文详细介绍了如何...通过阅读本文,我们可以学习到如何利用JavaScript的原生功能来模拟jQuery选择器,这不仅有助于深入理解DOM操作的原理,也有助于在特定情况下减少项目对外部库的依赖,从而优化性能和加载时间。

    jquery周历选择器

    本项目“jquery周历选择器”利用jQuery的灵活性和易用性,构建了一个适用于混合应用程序(Hybrid App)的周历选择器组件。 1. **周历选择器设计**: - 周历选择器通常用于日程管理或时间规划应用,显示一周的日期...

    h5PickerView纯原生Javascript实现的移动端多级选择器插件

    《纯原生JavaScript实现的移动端多级选择器插件——h5PickerView详解》 在当前的移动互联网时代,前端开发者面临着对用户体验的极致追求,其中,轻量级且功能强大的组件库是不可或缺的工具。本文将深入探讨一款名为...

    jquery样式选择器插件源码demo

    通过阅读和理解这段源码,开发者不仅可以学习到jQuery选择器的工作原理,还能提升对CSS选择器、DOM操作以及JavaScript性能优化的理解。 总结来说,这个"jquery样式选择器插件"是一个浓缩的精华,它展示了如何用最少...

    JQuery各种选择器详解

    JQuery选择器,xpath类型等的选择器

    jQuery的Document元素选择

    // 使用jQuery选择元素 var element = $('#j1'); // 输出元素的内容 console.log(element.html()); ``` 在这个示例中,我们选择了ID为`j1`的`&lt;div&gt;`元素,并打印出了它的HTML内容。 #### 三、XPath与CSS结合使用 ...

    JQuery选择器帮助文档

    ### JQuery选择器帮助文档 #### 一、简介 本文档主要介绍了JQuery 1.3.2版本中的选择器功能,这些选择器可以帮助开发者高效地选取网页中的元素,从而实现对DOM的操作。JQuery的选择器简化了JavaScript原生操作DOM...

    仿华为官网纯原生JS+Css编写,无jquery

    开发者需要仔细分析这些文件,学习如何用原生JS和CSS实现类似华为官网的功能和界面,如导航栏的动态效果、轮播图、下拉菜单等。 通过此项目,开发者可以深入理解原生JavaScript和CSS的强大力量,提高代码效率,减少...

    JQuery快速学一(强悍的选择器)

    JavaScript原生选择器与jQuery选择器 虽然jQuery提供了一套强大的选择器系统,但需要注意的是,它也支持JavaScript原生的选择器API,如`querySelector()`和`querySelectorAll()`。这两个方法可以接受CSS选择器字符...

    H5移动端选择器,layPicker移动端日期选择器

    `layPicker`是一个专为移动端设计的jQuery选择器插件,尤其适用于微信环境和一些老旧版本的浏览器。本文将详细介绍`layPicker`的特性、用法以及如何自定义HTML,帮助开发者更好地理解和使用这个工具。 `layPicker`...

    jQuery datepicker 日期选择器 中文汉化版 开始日期结束日期

    jQuery UI的日期选择器(jQuery datepicker)是一个广泛使用的组件,尤其在网页表单中用于输入日期时。这个组件提供了一个优雅、用户友好的界面,允许用户通过日历视图来选择日期,而不是手动输入。在中文环境中,...

    老生常谈jquery id选择器和class选择器的区别

    5. 从功能上来说,虽然CSS选择器的语法和jQuery选择器相似,但CSS选择器是为样式服务,而jQuery选择器是为添加行为(动作)服务。 了解了id选择器和class选择器的区别之后,开发者可以根据实际需要灵活运用这两种...

    jquery 属性选择器的使用

    jQuery 的属性选择器是前端开发中不可或缺的工具,它们使我们能够根据元素的属性进行精确选择,从而实现更精细的控制。了解并熟练运用这些选择器,能提升代码的灵活性和可维护性,使前端开发更加得心应手。结合实际...

    演员选择框三级联动(原生javascript和jquery实现)

    1. 使用`$(selector)`选择器获取元素。 2. 使用`.on('change', function() {...})`绑定事件监听。 3. 在事件回调函数中,利用`.html()`或`.append()`方法更新下级选择框的选项。 在提供的压缩包文件"Actor"中,可能...

    Android时间选择器样式jquery插件

    然后,通过选择一个HTML元素并调用相应的jQuery方法来初始化时间选择器。例如: ```html &lt;!DOCTYPE html&gt; &lt;html lang="zh"&gt; &lt;title&gt;Android时间选择器示例 &lt;script src="path/to/jquery.min.js"&gt; ...

    jQuery树形选择器代码.zip

    jQuery作为一个强大的JavaScript库,提供了丰富的选择器来操作DOM元素,但原生的jQuery并不直接支持树形结构的创建。然而,开发者们通过巧妙地利用jQuery的API,可以实现自定义的树形选择器,以满足这种需求。本篇...

    jQuery基础和jQuery选择器教程

    ### jQuery选择器 jQuery的选择器是其强大之处,它们基于CSS选择器,但扩展了一些额外的功能。 1. **基本选择器**: 包括 `ID选择器 (#)`, `类选择器 (.)`, 和 `元素选择器 (*)`,如: ```javascript $("#myID");...

Global site tag (gtag.js) - Google Analytics