做前端,需要选择元素,虽说有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这样的伪类选择。
相关推荐
本文详细介绍了如何...通过阅读本文,我们可以学习到如何利用JavaScript的原生功能来模拟jQuery选择器,这不仅有助于深入理解DOM操作的原理,也有助于在特定情况下减少项目对外部库的依赖,从而优化性能和加载时间。
最后,将选择器绑定到HTML元素上,即可在页面上看到效果。同时,阅读库的文档将有助于理解其具体用法和API,以便更好地定制和控制选择器的行为。 总的来说,基于jQuery的H5移动端选择器是现代Web开发中不可或缺的一...
本项目“jquery周历选择器”利用jQuery的灵活性和易用性,构建了一个适用于混合应用程序(Hybrid App)的周历选择器组件。 1. **周历选择器设计**: - 周历选择器通常用于日程管理或时间规划应用,显示一周的日期...
《纯原生JavaScript实现的移动端多级选择器插件——h5PickerView详解》 在当前的移动互联网时代,前端开发者面临着对用户体验的极致追求,其中,轻量级且功能强大的组件库是不可或缺的工具。本文将深入探讨一款名为...
通过阅读和理解这段源码,开发者不仅可以学习到jQuery选择器的工作原理,还能提升对CSS选择器、DOM操作以及JavaScript性能优化的理解。 总结来说,这个"jquery样式选择器插件"是一个浓缩的精华,它展示了如何用最少...
JQuery选择器,xpath类型等的选择器
// 使用jQuery选择元素 var element = $('#j1'); // 输出元素的内容 console.log(element.html()); ``` 在这个示例中,我们选择了ID为`j1`的`<div>`元素,并打印出了它的HTML内容。 #### 三、XPath与CSS结合使用 ...
### JQuery选择器帮助文档 #### 一、简介 本文档主要介绍了JQuery 1.3.2版本中的选择器功能,这些选择器可以帮助开发者高效地选取网页中的元素,从而实现对DOM的操作。JQuery的选择器简化了JavaScript原生操作DOM...
开发者需要仔细分析这些文件,学习如何用原生JS和CSS实现类似华为官网的功能和界面,如导航栏的动态效果、轮播图、下拉菜单等。 通过此项目,开发者可以深入理解原生JavaScript和CSS的强大力量,提高代码效率,减少...
`layPicker`是一个专为移动端设计的jQuery选择器插件,尤其适用于微信环境和一些老旧版本的浏览器。本文将详细介绍`layPicker`的特性、用法以及如何自定义HTML,帮助开发者更好地理解和使用这个工具。 `layPicker`...
JavaScript原生选择器与jQuery选择器 虽然jQuery提供了一套强大的选择器系统,但需要注意的是,它也支持JavaScript原生的选择器API,如`querySelector()`和`querySelectorAll()`。这两个方法可以接受CSS选择器字符...
在JavaScript中,我们可以使用原生DOM操作、jQuery库或者其他前端框架(如React、Vue或Angular)来实现级联选择器。这里我们以原生JS为例,简要介绍其基本实现步骤: 1. **创建HTML结构**:首先,我们需要创建一个...
jQuery UI的日期选择器(jQuery datepicker)是一个广泛使用的组件,尤其在网页表单中用于输入日期时。这个组件提供了一个优雅、用户友好的界面,允许用户通过日历视图来选择日期,而不是手动输入。在中文环境中,...
5. 从功能上来说,虽然CSS选择器的语法和jQuery选择器相似,但CSS选择器是为样式服务,而jQuery选择器是为添加行为(动作)服务。 了解了id选择器和class选择器的区别之后,开发者可以根据实际需要灵活运用这两种...
jQuery 的属性选择器是前端开发中不可或缺的工具,它们使我们能够根据元素的属性进行精确选择,从而实现更精细的控制。了解并熟练运用这些选择器,能提升代码的灵活性和可维护性,使前端开发更加得心应手。结合实际...
Framework7手机省市区城市选择器代码。Framework7 是一个开源免费的框架可以用来开发混合移动应用(原生和HTML混合)或者开发 iOS & Android 风格的WEB APP。 Framework7 最主要的功能是可以使用HTML、CSS和JS来开发...
1. 使用`$(selector)`选择器获取元素。 2. 使用`.on('change', function() {...})`绑定事件监听。 3. 在事件回调函数中,利用`.html()`或`.append()`方法更新下级选择框的选项。 在提供的压缩包文件"Actor"中,可能...
然后,通过选择一个HTML元素并调用相应的jQuery方法来初始化时间选择器。例如: ```html <!DOCTYPE html> <html lang="zh"> <title>Android时间选择器示例 <script src="path/to/jquery.min.js"> ...