function getIndex(ele){

var parent=ele.parentNode;
var brothers=parent.children;

for(var i=0,len=brothers.length;i<len;i++){

if(ele==brothers[i]){

return i;

}

}

}

function falseArrToTrue(arr){

return Array.prototype.slice.call(arr);
}

function getElementsByClassName(obj,name){

var obj = obj || window.document;
var els=obj.getElementsByTagName("*");
var arr=[];

for(var i=0,len=els.length;i<len;i++){

if(els[i].className==name){

arr.push(els[i]);
}

}

return arr;
}

function addEvent(obj,type,fn){

if(obj.attachEvent){

obj.attachEvent("on"+type,function(event){

if(false==fn.call(obj)){

var event=event || window.event;
event.cancelBubble=true;
return false;

}

});
}

else if(obj.addEventListener){

obj.addEventListener(type,function(event){

if(false==fn()){

event.preventDefault();
event.cancelBubble=true;

}

},false);

}

}

function getStyle(obj,style){

return window.getComputedStyle ? window.getComputedStyle(obj,null)[style]:obj.currentStyle[style];

}

function Vjquery(arg){

this.elements=[];

switch(typeof arg){

case "string":

switch(arg.charAt(0)){

case "#":
var el=document.getElementById(arg.substring(1));
this.elements.push(el);
break;
case ".":
this.elements=getElementsByClassName(document,arg.substring(1));
break;
default:

this.elements=document.getElementsByTagName(arg);

}
break;

case "function":

addEvent(window,"load",arg);
break;

case "object":
this.elements.push(arg);
break;

}

}

Vjquery.prototype={

extend:function(key,value){

Vjquery.prototype[key]=value;

},

eq:function(n){

return $(this.elements[n]);

},

each:function(fn){

for(var i=0,len=this.elements.length;i<len;i++)

fn(i,this.elements[i]);

},

find:function(arg){

var res=[];
for(var i=0,len=this.elements.length;i<len;i++){

switch(arg.charAt(0)){

case "." :

var arr=getElementsByClassName(this.elements[i],arg.substring(1));
res=res.concat(arr);

var vqueryObj=new Vjquery();
vqueryObj.elements=res;
return vqueryObj;
break;

default :

var arr=falseArrToTrue(this.elements[i].getElementsByTagName(arg));
res=res.concat(arr);

var vqueryObj=new Vjquery();
vqueryObj.elements=res;
return vqueryObj;

}

}

},

index:function(){

return getIndex(this.elements.slice(-1)[0]);

},

click:function(fn){

for(var i=0,len=this.elements.length;i<len;i++){

addEvent(this.elements[i],"click",fn);

}

return this;

},

size:function(){

return this.elements.length;
},

bind:function(type,fn){

for(var i=0,len=this.elements.length;i<len;i++){

addEvent(this.elements[i],type,fn);

}

return this;

},

show:function(){

for(var i=0,len=this.elements.length;i<len;i++){

if(this.elements[i].nodeType==1){

this.elements[i].style.display="block";

}

}

return this;
},

hide:function(){

for(var i=0,len=this.elements.length;i<len;i++){

if(this.elements[i].nodeType==1){

this.elements[i].style.display="none";

}

}

return this;

},

toggle:function(f1,f2){

var _arguments=arguments;
var length=_arguments.length;
var index=0;

console.log(index);

this.click(function(){

_arguments[index]();
index=(++index)%length;

});

return this;

},

hover:function(overfn,outfn){

for(var i=0,len=this.elements.length;i<len;i++){

if(this.elements[i].nodeType==1){

addEvent(this.elements[i],"mouseover",overfn);
addEvent(this.elements[i],"mouseout",outfn);

}

}

return this;

},

css:function(name,value){ //参数有可能是json

if(typeof name=="string"){

for(var i=0,len=this.elements.length;i<len;i++){

if(this.elements[i].nodeType==1){

if(arguments.length==2){

this.elements[i].style[name]=value;
}

else if(arguments.length==1){

return getStyle(this.elements[0],name);
}

}
}

}

else if(typeof name=="object"){

for(var i=0,len=this.elements.length;i<len;i++){

for(var key in name ){

this.elements[i].style[key]=name[key];

}

}

}

return this;

},

attr:function(arg){

for(var i=0,len=this.elements.length;i<len;i++){

if(this.elements[i].nodeType==1){

if(arguments.length==2){

this.elements[i].setAttribute([arguments[0]],arguments[1]);
}

else if(arguments.length==1){

this.elements[i].getAttribute([arguments[0]]);
}

}

}

return this;

}

}

function $(str){

return new Vjquery(str);
}

自己封装jquery的一些方法 链式调用模式的更多相关文章

  1. Ajax请求Session超时的解决办法:拦截器 + 封装jquery的post方法

    目标:前端系统,后端系统等,统一处理Session超时和系统错误的问题. 可能需要处理的问题:Session超时.系统500错误.普通的业务错误.权限不足. 同步请求:            Sess ...

  2. JavaScript基础对象创建模式之链式调用模式(Chaining Pattern)(029)

    链式调用模式允许一个接一个地调用对象的方法.这种模式不考虑保存函数的返回值,所以整个调用可以在同一行内完成: myobj.method1("hello").method2().me ...

  3. 如何写 JS 的链式调用 ---》JS 设计模式《----方法的链式调用

    1.以$ 函数为例.通常返回一个HTML元素或一个元素集合. 代码如下: function $(){ var elements = []; ;i<arguments.length;i++){ v ...

  4. jquery中链式调用原理

    (1).链式调用 $("#mybtn").css("width","100px") .css("height",&quo ...

  5. [js高手之路] 设计模式系列课程 - jQuery的链式调用与灵活的构造函数

    一.我们从一个简单的构造函数+原型程序开始 var G = function(){}; G.prototype = { length : 5, size : function(){ return th ...

  6. 使用es6的then()方法封装jquery的ajax请求

    使用场景: jsp页面中使用jquery的ajax请求比较频繁,以前vue框架的项目用过axios,所以就想着用then()封装一个公共请求的方法,这样每次请求就不用那么麻烦的写一大堆请求参数了. 示 ...

  7. 封装一个类似jquery的ajax方法

    //封装一个类似jquery的ajax方法,当传入参数,就可以发送ajax请求 //参数格式如下{ // type:"get"/"post", // dataT ...

  8. 34、[源码]-AOP原理-链式调用通知方法

    34.[源码]-AOP原理-链式调用通知方法

  9. JQuery 插件一般方法

    如今做web开发,jquery 几乎是必不可少的,就连vs神器在2010版本开始将Jquery 及ui 内置web项目里了.至于使用jquery好处这里就不再赘述了,用过的都知道.今天我们来讨论下jq ...

随机推荐

  1. git的权威指南

    CHENYILONG 博客 git的权威指南 全屏 © chenyilong.本站由Postach.io 博客

  2. c++刷题(37/100)笔试题2

    4道题2小时,又是一道,不过这次的比较难,但第二道不应该的,又是审题不仔细导致没过 题目1: 给定一个字符串,请你将字符串重新编码,将连续的字符替换成“连续出现的个数+字符”.比如字符串AAAABCC ...

  3. oracle开机自启,开机自动关闭防火墙,开机监听自启

    1.修改oratab 2,修改rc.local 3.关闭防火墙,设置开机时清空所有规则 参考文章: 1.https://blog.csdn.net/weeknd/article/details/726 ...

  4. 【Python】Flask系列-数据库笔记

    MySQL-python中间件的介绍与安装: 1.如果是在类unix系统上,直接进入虚拟环境,输入sudo pip install mysql-python. 2.如果是在windows系统上,那么在 ...

  5. c# 获取百度最后的url

    using System;using System.Collections.Generic;using System.Linq;using System.Net.Http;using System.T ...

  6. vue 兼容IE报错解决方案

    IE 页面空白 报错信息 此时页面一片空白 报错原因 Babel 默认只转换新的 JavaScript 语法(如箭头函数),而不转换新的 API ,比如 Iterator.Generator.Set. ...

  7. centos6.5环境通过rpm包安装mysql5.5.51数据库

    centos6.5环境通过rpm包安装mysql5.5.51数据库 注意:此方法适用于单独安装数据库的需求,如果在该机器上还需要安装php环境,建议mysql通过编译或yum方式安装 1.查找已经安装 ...

  8. jenkins的svn路径中文问题

    今天弄Jenkins,我们的SVN代码路径是中文的,他娘的坑死我了,很没面子弄了俩点,网上方案试了好多,说装插件,修改Tomcat server.xml,基本没用,后来看到一个帖子写的方案蛮实用的,分 ...

  9. PHP使用某个键值对二维数组排序

    $arr=[ array( 'name'=>'A', 'age'=>28 ), array( 'name'=>'B', 'age'=>14 ), array( 'name'=& ...

  10. SqlServer共用表达式(CTE)With As

    共用表表达式(CTE)可以看成是一个临时的结果集,可以再SELECT,INSERT,UPDATE,DELETE,MARGE语句中多次引用. 一好处:使用共用表表达式可以让语句更加清晰简练. 1.可以定 ...