js实例教程-原生仿写Jquery代码分析

发布时间:2018-11-25 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了js实例教程-原生仿写Jquery代码分析脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

原生仿写jquery代码分析

 ``` <script tyPE="text/javascript"> // 参数分三种情况: // 1. 字符串:选择器 // 2. function:ready方法 // 3. 原生对象:原生对象转JQ对象 function JQ(arg){ // 用来放原生对象的数组 this.elements = []; swITch (typeof arg){ case "string": // 通过getEle获取的有两种情况: id是一个对象,class和tag是数组 VAR result = getEle(arg); if (result.length > 1) {       this.elements = result; }else{       this.elements.push(result); }       break; case "function":       ready(arg);       break; case "object":       this.elements.push(arg);       break; } } // JQ对象转原生 JQ.PRototype.get = function(index){ return this.elements[index]; } // 从JQ对象中取出某一个原生对象,再转成新的JQ对象 JQ.prototype.eq = function(index){ return new JQ(this.elements[index]); } // $("p").eq(2).css() // defer表示当DOM加载完成之后再去加载script标签 // IE8之前 function ready(fn){ // DOMContentLoaded;DOM加载完成之后浏览器发出的通知 if (window.addEventListener) { window.addEventListener("DOMContentLoaded","fn","false") }else{ var script = document.createElement("script"); script.defer = true; var head = document.getelementsbytagname("head")[0]; script.onreadystatechange = function(){ if (script.readyState == "complete") { fn();}}}} // $("p")当JQ的参数只有一级选择器的时候 function getEle(selector){ // 1.去掉首尾空格 var reg = /^/s+|/s+$/g; selector.replace(reg,""); // 2.判断选择器类型 if (/^#/.test(selector)) { // id选择器 return document.getElementById(selector); }else if (/^./.test(selector)) { // class选择器 return getEleByClass(selector); }else{ return document.getElementsByTagName(selector);}} // 因为getElementsByclassname存在兼容性,所以单独处理 function getEleByClass(selector){ if (document.getElementsByClassName) { return document.getElementsByClassName(selector); }else{ // IE不支持直接根据className查找,所以需要一个一个遍历 var nodes = document.getElementsByTagName("*"); var arr = []; for (var i = 0;i < nodes.length;i++) { if (nodes[i].className == selector) { arr.push(nodes[i]); }} return arr; }} function $(arg){ return new JQ(arg); } </script> ```

原生仿写Jquery代码分析

 ``` <script type="text/javascript"> // 参数分三种情况: // 1. 字符串:选择器 // 2. function:ready方法 // 3. 原生对象:原生对象转JQ对象 function JQ(arg){ // 用来放原生对象的数组 this.elements = []; switch (typeof arg){ case "string": // 通过getEle获取的有两种情况: id是一个对象,class和tag是数组 var result = getEle(arg); if (result.length > 1) {       this.elements = result; }else{       this.elements.push(result); }       break; case "function":       ready(arg);       break; case "object":       this.elements.push(arg);       break; } } // JQ对象转原生 JQ.prototype.get = function(index){ return this.elements[index]; } // 从JQ对象中取出某一个原生对象,再转成新的JQ对象 JQ.prototype.eq = function(index){ return new JQ(this.elements[index]); } // $("p").eq(2).css() // defer表示当DOM加载完成之后再去加载script标签 // IE8之前 function ready(fn){ // DOMContentLoaded;DOM加载完成之后浏览器发出的通知 if (window.addEventListener) { window.addEventListener("DOMContentLoaded","fn","false") }else{ var script = document.createElement("script"); script.defer = true; var head = document.getElementsByTagName("head")[0]; script.onreadystatechange = function(){ if (script.readyState == "complete") { fn();}}}} // $("p")当JQ的参数只有一级选择器的时候 function getEle(selector){ // 1.去掉首尾空格 var reg = /^/s+|/s+$/g; selector.replace(reg,""); // 2.判断选择器类型 if (/^#/.test(selector)) { // id选择器 return document.getElementById(selector); }else if (/^./.test(selector)) { // class选择器 return getEleByClass(selector); }else{ return document.getElementsByTagName(selector);}} // 因为getElementsByClassName存在兼容性,所以单独处理 function getEleByClass(selector){ if (document.getElementsByClassName) { return document.getElementsByClassName(selector); }else{ // IE不支持直接根据className查找,所以需要一个一个遍历 var nodes = document.getElementsByTagName("*"); var arr = []; for (var i = 0;i < nodes.length;i++) { if (nodes[i].className == selector) { arr.push(nodes[i]); }} return arr; }} function $(arg){ return new JQ(arg); } </script> ```

觉得可用,就经常来吧!Javascript技巧 脚本宝典 欢迎评论哦!&nbsp;js技巧,巧夺天工,精雕玉琢。小宝典献丑了!

脚本宝典总结

以上是脚本宝典为你收集整理的js实例教程-原生仿写Jquery代码分析全部内容,希望文章能够帮你解决js实例教程-原生仿写Jquery代码分析所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。