原生仿写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> ```
如对本文有疑问, 点击进行留言回复!!
150Vue-Router路由概述+基本使用router-view占位符+重定向redirect
网友评论