JavaScript中链式调用之研习


Posted in Javascript onApril 07, 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) 
...

相关:
我的函数链之演变
Javascript 相关文章推荐
JavaScript 新手24条实用建议[TUTS+]
Jun 21 Javascript
JavaScript ( (__ = !$ + $)[+$] + ({} + $)[_/_] +({} + $)[_/_] )
Feb 25 Javascript
各浏览器对link标签onload/onreadystatechange事件支持的差异分析
Apr 27 Javascript
IE 当eval遇上function的处理
Aug 09 Javascript
js 判断浏览器使用的语言示例代码
Mar 22 Javascript
jquery easyui 结合jsp简单展现table数据示例
Apr 18 Javascript
javascript引用赋值(地址传值)用法实例
Jan 13 Javascript
jQuery实现可用于博客的动态滑动菜单
Mar 09 Javascript
基于Jquery easyui 选中特定的tab
Nov 17 Javascript
微信小程序动态增加按钮组件
Sep 14 Javascript
Vue 3.0双向绑定原理的实现方法
Oct 23 Javascript
Vue 组件复用多次自定义参数操作
Jul 27 Javascript
js中各浏览器中鼠标按键值的差异
Apr 07 #Javascript
javascript 单例/单体模式(Singleton)
Apr 07 #Javascript
Safari5中alert的无限循环BUG
Apr 07 #Javascript
JQuery中html()方法使用不当带来的陷阱
Apr 07 #Javascript
仅IE6/7/8中innerHTML返回值忽略英文空格的问题
Apr 07 #Javascript
jQuery为iframe的body添加click事件的实现代码
Apr 07 #Javascript
JQUERY的属性选择符和自定义选择符使用方法(二)
Apr 07 #Javascript
You might like
PHP文件操作实例总结
2016/09/27 PHP
php封装db类连接sqlite3数据库的方法实例
2017/12/19 PHP
php 中phar包的使用教程详解
2018/10/26 PHP
PHP随机生成中文段落示例【测试网站内容时使用】
2020/04/26 PHP
javascript document.referrer 用法
2009/04/30 Javascript
Jquery + Ajax调用webService实例代码(asp.net)
2010/08/27 Javascript
js过滤HTML标签以及空格的思路及代码
2013/05/24 Javascript
$.getJSON在IE下失效的原因分析及解决方法
2013/06/16 Javascript
自定义的一个简单时尚js下拉选择框
2013/11/20 Javascript
jquery移动端TAB触屏切换实现效果
2020/12/22 Javascript
在AngularJS框架中处理数据建模的方式解析
2016/03/05 Javascript
angular2 ng build部署后base文件路径问题详细解答
2017/07/15 Javascript
微信小程序progress组件使用详解
2018/01/31 Javascript
JQuery元素快速查找与操作
2018/04/22 jQuery
vue.js多页面开发环境搭建过程
2019/04/24 Javascript
jQuery - AJAX load() 实例用法详解
2019/08/27 jQuery
JS中循环遍历数组的四种方式总结
2021/01/23 Javascript
[07:47]DOTA2国际邀请赛采访专栏:探访Valve总部
2013/08/08 DOTA
Python使用random和tertools模块解一些经典概率问题
2015/01/28 Python
Python3实现发送QQ邮件功能(文本)
2017/12/15 Python
Python闭包函数定义与用法分析
2018/07/20 Python
Python实现word2Vec model过程解析
2019/12/16 Python
Tensorflow 实现分批量读取数据
2020/01/04 Python
基于pandas向csv添加新的行和列
2020/05/25 Python
python如何删除列为空的行
2020/07/17 Python
Kenneth Cole官网:纽约时尚优雅品牌
2016/11/14 全球购物
Pretty Green美国:英式摇滚服饰风格代表品牌之一
2019/01/23 全球购物
大学生学年自我鉴定
2014/02/10 职场文书
我的长生果教学反思
2014/04/28 职场文书
2014年作风建设剖析材料
2014/10/23 职场文书
2014保险公司个人工作总结
2014/12/09 职场文书
2014年街道办事处工作总结
2014/12/11 职场文书
2015年物业管理工作总结
2015/04/23 职场文书
社会心理学学习心得体会
2016/01/22 职场文书
2016党员学习心得体会范文
2016/01/23 职场文书
Ruby处理YAML和json数据
2022/04/18 Ruby