摘要:原生仿写Jquery代码分析原生仿写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技巧 脚本宝典 欢迎评论哦! js技巧,巧夺天工,精雕玉琢。小宝典献丑了!

本文固定链接: http://www.js-code.com/js/js_1278.html