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取消单选按钮选中示例代码
Nov 14 Javascript
Jquery 获取指定标签的对象及属性的设置与移除
May 29 Javascript
js实现获取当前时间是本月第几周的方法
Aug 11 Javascript
微信开发 js实现tabs选项卡效果
Oct 28 Javascript
微信小程序 选择器(时间,日期,地区)实例详解
Nov 16 Javascript
js 简易版滚动条实例(适用于移动端H5开发)
Jun 26 Javascript
vue响应式系统之observe、watcher、dep的源码解析
Apr 09 Javascript
Vue项目中使用WebUploader实现文件上传的方法
Jul 21 Javascript
JavaScript:ES2019 的新特性(译)
Aug 08 Javascript
layUI的验证码功能及校验实例
Oct 25 Javascript
vue iview实现动态新增和删除
Jun 17 Javascript
微信小程序实现翻牌抽奖动画
Sep 21 Javascript
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本地服务器分享
2013/02/19 PHP
PHP字符串的编码问题的详细介绍
2013/04/27 PHP
PHP中func_get_args(),func_get_arg(),func_num_args()的区别
2013/09/30 PHP
PHP控制反转(IOC)和依赖注入(DI)
2017/03/13 PHP
PHP实现15位身份证号转18位的方法分析
2019/10/16 PHP
ThinkPHP5与单元测试PHPUnit使用详解
2020/02/23 PHP
jQuery在html有效在jsp无效的原因及解决方法
2013/08/02 Javascript
Javascript 是你的高阶函数(高级应用)
2015/06/15 Javascript
jquery.validate[.unobtrusive]和Bootstrap实现tooltip错误提示问题分析
2016/10/30 Javascript
JavaScript实现解析INI文件内容的方法
2016/11/17 Javascript
javascript简单链式调用案例分析
2017/05/10 Javascript
基于BootStrap的前端分页带省略号和上下页效果
2017/05/18 Javascript
JavaScript变量类型以及变量作用域详解
2017/08/14 Javascript
VUE2实现事件驱动弹窗示例
2017/10/21 Javascript
微信小程序滑动选择器的实现代码
2018/08/10 Javascript
NodeJs 文件系统操作模块fs使用方法详解
2018/11/26 NodeJs
浅谈layui里的上传控件问题
2019/09/26 Javascript
vue实现图片按比例缩放问题操作
2020/08/11 Javascript
Python实现爬取知乎神回复简单爬虫代码分享
2015/01/04 Python
Python中的if、else、elif语句用法简明讲解
2016/03/11 Python
Python实现的下载网页源码功能示例
2017/06/13 Python
Python内存管理方式和垃圾回收算法解析
2017/11/11 Python
Python实现动态图解析、合成与倒放
2018/01/18 Python
Python爬虫的两套解析方法和四种爬虫实现过程
2018/07/20 Python
浅析Python四种数据类型
2018/09/26 Python
Html+Css+Jquery实现左侧滑动拉伸导航菜单栏的示例代码
2020/03/17 HTML / CSS
民族学专业求职信
2014/07/28 职场文书
企业群众路线教育实践活动心得体会
2014/11/03 职场文书
2014年评职称工作总结
2014/11/20 职场文书
升学宴学生致辞
2015/07/27 职场文书
党风廉政承诺书2016
2016/03/25 职场文书
浅谈自定义校验注解ConstraintValidator
2021/06/30 Java/Android
python识别围棋定位棋盘位置
2021/07/26 Python
Python语言内置数据类型
2022/02/24 Python
MySQL中B树索引和B+树索引的区别详解
2022/03/03 MySQL
MongoDB数据库部署环境准备及使用介绍
2022/03/21 MongoDB