极乐门资源网 Design By www.ioogu.com
JQuery作为应用最广的JS库,其最强大的功能之一就是几乎涵盖所有方法的且代码十分简短的选择器功能,我们也可用自己的代码实现此功能,代码逻辑、使用方法与JQuery一致
function ZQuery(arg){ this.elements = []; //存东西 this.domString = ''; //保存字符串标签 if(typeof arg=='function'){ //DOMReady DOMReady(arg); }else if(typeof arg=='string'||arg instanceof String){ if(arg.indexOf('<')!=-1){ this.domString = arg; }else{ //获取元素 this.elements = getEle(arg); this.length = this.elements.length; } }else{ //原生对象-》ZQuery对象 this.elements.push(arg); this.length = this.elements.length; } } ZQuery.prototype.css = function(name,value){ if(arguments.length==2){ //设置一个样式 for(var i=0;i<this.elements.length;i++){ this.elements[i].style[name] = value; } }else{ if(typeof name=='string'){ //获取样式 return getStyle(this.elements[0],name); }else{ //批量设置样式 var json = name; for(var name in json){ for(var i=0;i<this.elements.length;i++){ this.elements[i].style[name] = json[name]; } } } } }; ZQuery.prototype.attr = function(name,value){ if(arguments.length==2){ //设置一个属性 for(var i=0;i<this.elements.length;i++){ this.elements[i].setAttribute(name,value); } }else{ if(typeof name=='string'){ //获取属性 return this.elements[0].getAttribute(name); }else{ //批量设置属性 var json = name; for(var name in json){ for(var i=0;i<this.elements.length;i++){ this.elements[i].setAttribute(name,json[name]); } } } } }; ZQuery.prototype.addClass = function(sClass){ var re = new RegExp('\\b'+sClass+'\\b','g'); for(var i=0;i<this.elements.length;i++){ if(this.elements[i].className){ if(this.elements[i].className.search(re)==-1){ this.elements[i].className += ' '+sClass; } }else{ this.elements[i].className = sClass; } this.elements[i].className = this.elements[i].className.replace(/^\s+|\s+$/g,'').replace(/\s+/g,' '); } return this; }; ZQuery.prototype.removeClass = function(sClass){ var re = new RegExp('\\b'+sClass+'\\b','g'); for(var i=0;i<this.elements.length;i++){ if(this.elements[i].className){ this.elements[i].className = this.elements[i].className.replace(re,''); this.elements[i].className = this.elements[i].className.replace(/^\s+|\s+$/g,'').replace(/\s+/g,' '); if(this.elements[i].className==''){ this.elements[i].removeAttribute('class'); } } } return this; }; ZQuery.prototype.html = function(value){ if(value||value==''){ //设置 for(var i=0;i<this.elements.length;i++){ this.elements[i].innerHTML = value; } }else{ return this.elements[0].innerHTML; } }; ZQuery.prototype.val = function(value){ if(value||value==''){ //设置 for(var i=0;i<this.elements.length;i++){ this.elements[i].value = value; } }else{ return this.elements[0].value; } }; ZQuery.prototype.show = function(){ for(var i=0;i<this.elements.length;i++){ this.elements[i].style.display = 'block'; } return this; }; ZQuery.prototype.hide = function(){ for(var i=0;i<this.elements.length;i++){ this.elements[i].style.display = 'none'; } return this; }; ;'click mouseover mouseout mousedown mouseup mousemove mouseenter mouseleave change keydown keyup contextmenu'.replace(/\w+/g,function(str){ ZQuery.prototype[str] = function(fn){ for(var i=0;i<this.elements.length;i++){ addEvent(this.elements[i],str,fn); } }; }); ZQuery.prototype.get = function(n){ for(var i=0;i<this.elements.length;i++){ if(i==n){ return this.elements[i]; } } }; ZQuery.prototype.eq = function(n){ for(var i=0;i<this.elements.length;i++){ if(i==n){ return $(this.elements[i]); } } }; ZQuery.prototype.index = function(){ var aSiblings = this.elements[0].parentNode.children; for(var i=0;i<aSiblings.length;i++){ if(aSiblings[i]==this.elements[0]){ return i; } } }; ZQuery.prototype.hover = function(fn1,fn2){ for(var i=0;i<this.elements.length;i++){ $(this.elements[i]).mouseenter(fn1); $(this.elements[i]).mouseleave(fn2); } }; ZQuery.prototype.toggle = function(){ var args = arguments; var _this = this; for(var i=0;i<this.elements.length;i++){ ;(function(count){ $(_this.elements[i]).click(function(ev){ args[count%args.length].call(this,ev); count++; }); })(0); } }; ZQuery.prototype.animate = function(json,options){ for(var i=0;i<this.elements.length;i++){ move(this.elements[i],json,options); } }; ZQuery.prototype.appendTo = function(arg){ var aParent = $(arg); for(var i=0;i<aParent.length;i++){ aParent.get(i).insertAdjacentHTML('beforeEnd',this.domString); } return this; }; ZQuery.prototype.prependTo = function(arg){ var aParent = $(arg); for(var i=0;i<aParent.length;i++){ aParent.get(i).insertAdjacentHTML('afterBegin',this.domString); } return this; }; ZQuery.prototype.insertAfter = function(arg){ var aParent = $(arg); for(var i=0;i<aParent.length;i++){ aParent.get(i).insertAdjacentHTML('afterEnd',this.domString); } return this; }; ZQuery.prototype.insertBefore = function(arg){ var aParent = $(arg); for(var i=0;i<aParent.length;i++){ aParent.get(i).insertAdjacentHTML('beforeBegin',this.domString); } return this; }; ZQuery.prototype.remove = function(){ var oParent = this.elements[0].parentNode; for(var i=0;i<this.elements.length;i++){ oParent.removeChild(this.elements[i]); } return this; }; function $(arg){ return new ZQuery(arg); }; $.ajax = function(json){ ajax(json); }; $.jsonp = function(json){ jsonp(json); }; $.fn = ZQuery.prototype; $.fn.extend = function(json){ for(var name in json){ ZQuery.prototype[name] = json[name]; } }; function json2url(json){ var arr = []; for(var name in json){ arr.push(name+'='+encodeURIComponent(json[name])); } return arr.join('&'); } function ajax(json){ json = json||{}; if(!json.url)return; json.type = json.type||'get'; json.timeout = json.timeout||15000; json.data = json.data||{}; json.data.t = Math.random(); if(window.XMLHttpRequest){ var oAjax = new XMLHttpRequest(); }else{ var oAjax = new ActiveXObject('Microsoft.XMLHTTP'); } switch(json.type.toLowerCase()){ case 'get': oAjax.open('GET',json.url+'?'+json2url(json.data),true); oAjax.send(); break; case 'post': oAjax.open('POST',json.url,true); oAjax.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); oAjax.send(json2url(json.data)); break; default: oAjax.open('GET',json.url+'?'+json2url(json.data),true); oAjax.send(); break; } json.loading&&json.loading(); json.timer = setTimeout(function(){ oAjax.onreadystatechange = null; json.error&&json.error('网络超时。'); },json.timeout); oAjax.onreadystatechange = function(){ if(oAjax.readyState==4){ clearTimeout(json.timer); if(oAjax.status>=200&&oAjax.status<300||oAjax.status==304){ json.success&&json.success(oAjax.responseText); }else{ json.error&&json.error(oAjax.status); } } }; } function jsonp(json){ json = json||{}; if(!json.url)return; json.timeout = json.timeout||15000; json.cbName = json.cbName||'cb'; json.data = json.data||{}; json.data[json.cbName] = 'show'+Math.random(); json.data[json.cbName] = json.data[json.cbName].replace('.',''); json.timer = setTimeout(function(){ window[json.data[json.cbName]] = function(res){ oHead.removeChild(oS); json.error&&json.error('网络超时!'); } },json.timeout); window[json.data[json.cbName]] = function(res){ clearTimeout(json.timer); oHead.removeChild(oS); json.success&&json.success(res); } var oHead = document.getElementsByTagName('head')[0]; var oS = document.createElement('script'); oS.src = json.url+'?'+json2url(json.data); oHead.appendChild(oS); } function getStyle(obj,sName){ return (obj.currentStyle||getComputedStyle(obj,false))[sName]; } function addEvent(obj,sEv,fn){ if(obj.addEventListener){ obj.addEventListener(sEv,function(ev){ var oEvent = ev||event; if(fn.call(obj,oEvent)==false){ oEvent.cancelBubble = true; oEvent.preventDefault&&oEvent.preventDefault(); } },false); }else{ obj.attachEvent('on'+sEv,function(){ var oEvent = ev||event; if(fn.call(obj,oEvent)==false){ oEvent.cancelBubble = true; return false; } }); } } function DOMReady(fn){ if(document.addEventListener){ addEvent(document,'DOMContentLoaded',function(){ fn&&fn(); }); }else{ addEvent(document,'onreadystatechange',function(){ if(document.readyState=='complete'){ fn&&fn(); } }); } } function getByClass(oParent,sClass){ if(oParent.getElementsByClassName){ return oParent.getElementsByClassName(sClass); }else{ var aResult = []; var aEle = oParent.getElementsByTagName('*'); var re = new RegExp('\\b'+sClass+'\\b','g'); for(var i=0;i<aEle.length;i++){ if(aEle[i].className.search(re)!=-1){ aResult.push(aEle[i]); } } return aResult; } } function getByStr(aParent,str){ var aChild = []; //遍历父级 for(var i=0;i<aParent.length;i++){ switch(str.charAt(0)){ case '#': //#id aChild.push(document.getElementById(str.substring(1))); break; case '.': //.class var aEle = getByClass(aParent[i],str.substring(1)); for(var j=0;j<aEle.length;j++){ aChild.push(aEle[j]); } break; default: if(/^\w+\.\w+$/.test(str)){ //筛选 //li.on var arr = str.split('.'); var re = new RegExp('\\b'+arr[1]+'\\b','g'); var aEle = aParent[i].getElementsByTagName(arr[0]); for(var j=0;j<aEle.length;j++){ if(aEle[j].className.search(re)!=-1){ aChild.push(aEle[j]); } } }else if(/^\w+\[\w+\=\w+\]$/.test(str)){ //属性 var arr = str.split(/\[|\=|\]/); var aEle = aParent[i].getElementsByTagName(arr[0]); for(var j=0;j<aEle.length;j++){ if(aEle[j].getAttribute(arr[1]) == arr[2]){ aChild.push(aEle[j]); } } }else if(/^\w+\:\w+(\(\d+\))?$/.test(str)){ var arr = str.split(/\:|\(|\)/); var aEle = aParent[i].getElementsByTagName(arr[0]); switch(arr[1]){ case 'first': aChild.push(aEle[0]); break; case 'last': aChild.push(aEle[aEle.length-1]); break; case 'even': for(var j=0;j<aEle.length;j+=2){ aChild.push(aEle[j]); } break; case 'odd': for(var j=1;j<aEle.length;j+=2){ aChild.push(aEle[j]); } break; case 'eq': aChild.push(aEle[arr[2]]); break; case 'lt': for(var j=0;j<arr[2];j++){ aChild.push(aEle[j]); } break; case 'gt': for(var j=parseInt(arr[2])+1;j<aEle.length;j++){ aChild.push(aEle[j]); } break; } }else{ //标签 var aEle = aParent[i].getElementsByTagName(str); for(var j=0;j<aEle.length;j++){ aChild.push(aEle[j]); } } break; } } return aChild; } function getEle(str){ var arr = str.replace(/^\s+|\s+$/g,'').split(/\s+/); var aParent = [document]; var aChild = []; for(var i=0;i<arr.length;i++){ aChild = getByStr(aParent,arr[i]); //这一次获取到的子级,是下一次获取的父级 aParent = aChild; } return aChild; } function move(obj,json,options){ clearInterval(obj.timer); options=options || {}; options.easing=options.easing|| 'ease-out'; options.duration=options.duration || 800; var count=Math.floor(options.duration/30); var start={}; var dis={}; for(var name in json){ start[name]=parseFloat(getStyle(obj,name)); dis[name]=json[name]-start[name]; } var n=0; obj.timer=setInterval(function(){ n++; for(var name in json){ switch(options.easing){ case 'linear': var a=n/count; var cur=start[name]+dis[name]*a; break; case 'ease-in': var a=n/count; var cur=start[name]+dis[name]*a*a*a; break; case 'ease-out': var a=1-n/count; var cur=start[name]+dis[name]*(1-a*a*a); break; } if(name=='opacity'){ obj.style.opacity=cur; obj.style.filter='alpha(opacity:'+cur*100+')'; }else{ obj.style[name]=cur+'px'; } } if(n==count){ clearInterval(obj.timer); options.complete && options.complete(); } },30); }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
标签:
js,选择器
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无JS仿JQuery选择器功能的评论...
更新日志
2025年01月13日
2025年01月13日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]