JavaScript中两种链式调用实现代码


Posted in Javascript onJanuary 12, 2011

一、方法体内返回对象实例自身(this)

function ClassA(){ 
this.prop1 = null; 
this.prop2 = null; 
this.prop3 = null; 
} 
ClassA.prototype = { 
method1 : function(p1){ 
this.prop1 = p1; 
return this; 
}, 
method2 : function(p2){ 
this.prop2 = p2; 
return this; 
}, 
method3 : function(p3){ 
this.prop3 = p3; 
return this; 
} 
}

定义了function/类ClassA。有三个属性/字段prop1,prop2,prop3,三个方法methed1,method2,method3分别设置prop1,prop2,prop3。
链式调用如下:
var obj = new ClassA(); 
obj.method1(1).method2(2).method(3); // obj -> prop1=1,prop2=2,prop3=3

可以看到对obj进行了连续三次操作,只要愿意ClassA的N多方法都这样定义,调用链会一直延续。
该方式缺点是链方法唯一地绑定于一种对象类型(ClaaaA),按这种方式实现链式操作,每定义一个类,其方法体中都要返回this。第二种方式可以解决这个问题。
二、对象传入后每次调用返回函数自身
/** 
* chain 精简版 
* @param {Object} obj 
*/ 
function chain(obj){ 
return function(){ 
var Self = arguments.callee; Self.obj = obj; 
if(arguments.length==0){ 
return Self.obj; 
} 
Self.obj[arguments[0]].apply(Self.obj,[].slice.call(arguments,1)); 
return Self; 
} 
} //定义的function/类ClassB 
function ClassB(){ 
this.prop1 = null; 
this.prop2 = null; 
this.prop3 = null; 
} 
ClassB.prototype = { 
method1 : function(p1){ 
this.prop1 = p1; 
}, 
method2 : function(p2){ 
this.prop2 = p2; 
}, 
method3 : function(p3){ 
this.prop3 = p3; 
} 
}

注意ClassB的method1,method2,method3中不再返回this了。

链式调用如下:

var obj = new ClassB(); 
chain(obj)('method1',4)('method2',5)('method3',6); // obj -> prop1=4,prop2=5,prop3=6

第一种方式3次调用后返回了对象自身,这里使用一个空"()"取回对象
// result -> prop1=4,prop2=5,prop3=6 
var result = chain(obj)('method1',4)('method2',5)('method3',6)();

这种方式写类时方法体中无须返回this,且可以对任何对象进行链式调用。

从写法上总结下两种的调用方式:

obj 
.method1(arg1) 
.method2(arg2) 
.method3(arg3) 
... chain(obj) 
(method1,arg1) 
(method2,arg2) 
(method3,arg3) 
...

最后,感谢沐海,我是从wee库中获取以上灵感的。

/201101/yuanma/chain.rar

Javascript 相关文章推荐
js一般方法改写成面向对象方法的无限级折叠菜单示例代码
Jul 04 Javascript
几种设置表单元素中文本输入框不可编辑的方法总结
Nov 25 Javascript
用canvas 实现个图片三角化(LOW POLY)效果
Feb 18 Javascript
jQuery实现指定区域外单击关闭指定层的方法【经典】
Jun 22 Javascript
jQuery插件FusionCharts绘制2D柱状图和折线图的组合图效果示例【附demo源码】
Apr 10 jQuery
swiper 自动图片无限轮播实现代码
May 21 Javascript
解决vue打包css文件中背景图片的路径问题
Sep 03 Javascript
ExtJs使用自定义插件动态保存表头配置(隐藏或显示)
Sep 25 Javascript
实例分析Array.from(arr)与[...arr]到底有何不同
Apr 09 Javascript
js实现直播点击飘心效果
Aug 19 Javascript
关于JavaScript数组去重的一些理解汇总
Sep 10 Javascript
浅谈vue2的$refs在vue3组合式API中的替代方法
Apr 18 Vue.js
Chrome中JSON.parse的特殊实现
Jan 12 #Javascript
js中将字符串转换成json的三种方式
Jan 12 #Javascript
Javascript在IE下设置innerHTML时出现未知的运行时错误的解决方法
Jan 12 #Javascript
基于JQuery实现相同内容合并单元格的代码
Jan 12 #Javascript
jquery EasyUI的formatter格式化函数代码
Jan 12 #Javascript
Script的加载方法小结
Jan 12 #Javascript
javascrip客户端验证文件大小及文件类型并重置上传
Jan 12 #Javascript
You might like
PHP 函数执行效率的小比较
2010/10/17 PHP
记录PHP错误日志 display_errors与log_errors的区别
2012/10/09 PHP
PDO版本问题 Invalid parameter number: no parameters were bound
2013/01/06 PHP
LotusPhp笔记之:基于ObjectUtil组件的使用分析
2013/05/06 PHP
VIM中设置php自动缩进为4个空格的方法详解
2013/06/14 PHP
深入解析fsockopen与pfsockopen的区别
2013/07/05 PHP
PHP字符串的递增和递减示例介绍
2014/02/11 PHP
PHP实现WebService的简单示例和实现步骤
2015/03/27 PHP
微信公众平台开发之配置与请求
2015/08/26 PHP
PHP基于PDO调用sqlserver存储过程通用方法【基于Yii框架】
2017/10/07 PHP
javascript的变量、传值、传址、参数之间关系
2015/07/26 Javascript
Nodejs Express4.x开发框架随手笔记
2015/11/23 NodeJs
JavaScript中instanceof运算符的使用示例
2016/06/08 Javascript
IE11下使用canvas.toDataURL报SecurityError错误的解决方法
2017/11/19 Javascript
Vue 使用中的小技巧
2018/04/26 Javascript
小程序显示弹窗时禁止下层的内容滚动实现方法
2019/03/20 Javascript
jQuery实现全选、反选和不选功能的方法详解
2019/12/04 jQuery
Javascript原型链及instanceof原理详解
2020/05/25 Javascript
详解nginx配置vue h5 history去除#号
2020/11/09 Javascript
[31:00]2014 DOTA2华西杯精英邀请赛5 24 NewBee VS iG
2014/05/25 DOTA
对python中执行DOS命令的3种方法总结
2018/05/12 Python
django 通过url实现简单的权限控制的例子
2019/08/16 Python
Python中如何将一个类方法变为多个方法
2019/12/30 Python
django实现更改数据库某个字段以及字段段内数据
2020/03/31 Python
Python 如何创建一个线程池
2020/07/28 Python
python 实用工具状态机transitions
2020/11/21 Python
土木工程毕业生推荐信
2013/10/28 职场文书
机械设计职业生涯规划书
2013/12/27 职场文书
实习老师离校感言
2014/02/03 职场文书
购房公证委托书(2014版)
2014/09/12 职场文书
2014年安全生产工作总结
2014/11/13 职场文书
艺术节开幕词
2015/01/28 职场文书
酒店辞职书范文
2015/02/26 职场文书
2015年上半年党建工作总结
2015/03/30 职场文书
Python pandas读取CSV文件的注意事项(适合新手)
2021/06/20 Python
Python操作CSV格式文件的方法大全
2021/07/15 Python