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

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

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要快。
当然测试不可能全面,还可能会有bug,而且不支持类似于.content:first-child这样的伪类选择。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索选择器
HTML元素
js原生选择器、原生js class选择器、h5原生时间选择器、js原生日期选择器、原生js 属性选择器,以便于您获取更多的相关知识。

时间: 2024-09-28 02:11:53

原生的html元素选择器类似jquery选择器_javascript技巧的相关文章

利用原生JavaScript获取元素样式只是获取而已_javascript技巧

ps:是获取样式,不是设置样式.若没有给元素设置样式值,则返回浏览器给予的默认值.(论坛整理) 1.element.style:只能获取写在元素标签中的style属性里的样式值,无法获取到定义在<style></style>和通过<link href="css.css">加载进来的样式属性 复制代码 代码如下: var ele = document.getElementById('ele'); ele.style.color; //获取颜色 2.wi

常见的原始JS选择器使用方法总结_javascript技巧

常见的getElementById,getElementsByName,getElementsByTagName.但外国人不满意这些API,于是搞出了getElementsByClassName,后来一点点又出现了jQuery选择器,这里只说原始js选择. 1.getElementById 这是最常用的选择器,通过id来定位: 例: var test=document.getElementById("test").value;//获取文档中id为test的元素的值,并赋值给test变脸

JavaScript实现自己的DOM选择器原理及代码_javascript技巧

解释器模式(Interpreter):定义一种语法格式,通过程序解释执行它并完成相应的任务.在前端编程场景中可以应用解释器模式来解释CSS选择符实现DOM元素的选择. 开放封闭原则:面向对象中的开放封闭原则是类或模块应该对扩展开放对修改封闭,在这个dom选择器中实现id选择器,元素选择器,类选择器,如果以后需要属性选择器的话定义一个属性选择器实现相应的方法,同时在简单工厂中增加相应的创建属性选择器对象分支即可. 匹配原理:浏览器在匹配CSS选择符时是按照从右到左匹配的,所以实现自己的DOM选择器

快速查找数组中的某个元素并返回下标示例_javascript技巧

复制代码 代码如下: //常规实现一: function isHasElementOne(arr,value){ for(var i = 0,vlen = arr.length; i < vlen; i++){ if(arr[i] == value){ return i; } } return -1; } //实现二: function isHasElementTwo(arr,value){ var str = arr.toString(); var index = str.indexOf(va

Jquery颜色选择器ColorPicker实现代码_javascript技巧

在CMS中通常都有给标题添加颜色的功能,但一般都比较简单,颜色支持也少,这里我要分享一个自己修改的颜色选择器.界面简洁,功能强大.在我们的日常项目中可以快速的部署. 复制代码 代码如下: $(".colorpicker").colorpicker({ target:'#title', success:function(o,color){ $("#color").val(color) }, reset:function(o){ $("#color"

js实现点击文本框显示日期选择器特效代码分享_javascript技巧

为大家分享的JavaScript图片轮播代码如下 <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>js点击文本框显示日期选择器</title> <link type="text/css" rel="stylesheet" href="calen

原生js实现给指定元素的后面追加内容_javascript技巧

复制代码 代码如下: var header1 = document.getElementById("header"); var p = document.createElement("p"); // 创建一个元素节点 insertAfter(p,header1); // 因为js没有直接追加到指定元素后面的方法 所以要自己创建一个方法 function insertAfter( newElement, targetElement ){ // newElement是要

JS Jquery 遍历,筛选页面元素 自动完成(实现代码)_javascript技巧

复制代码 代码如下:         <script>        var value = "teset";        var s = new RegExp(value, "i")//I 表示不区分大小写(可省略)        $(".lico").each(function (i, n) {    //lico为所有li列表的class名 遍历            if (s.test($(n).text()))  //筛

JS动态创建元素的两种方法_javascript技巧

本文为大家分享了js创建元素的两种方法供大家参考,具体内容如下 1)将需要创建的元素,以字符串的形式拼接:找到父级元素,直接对父级元素的innnerHTML进行赋值. 2)使用Document.Element对象自带的一些函数,来实现动态创建元素(创建元素 => 找到父级元素 => 在指定位置插入元素) 一.字符串拼接形式     为了更好的理解,设定一个应用场景.     随机生成一组数字,将这组数据渲染为条形图的形式,放在div[id="container"]中,如下图