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 相关文章推荐
js操作ajax返回的json的注意问题!
Feb 23 Javascript
javascript的创建多行字符串的7种方法
Apr 29 Javascript
jQuery使用元素属性attr赋值详解
Feb 27 Javascript
jquery实现页面关键词高亮显示的方法
Mar 12 Javascript
vuejs在解析时出现闪烁的原因及防止闪烁的方法
Sep 19 Javascript
任意Json转成无序列表的方法示例
Dec 09 Javascript
JS实现简易的图片拖拽排序实例代码
Jun 09 Javascript
让bootstrap的carousel支持滑动滚屏的实现代码
Nov 27 Javascript
详解js的视频和音频采集
Aug 09 Javascript
Vue中android4.4不兼容问题的解决方法
Sep 04 Javascript
Angular6新特性之Angular Material
Dec 28 Javascript
小程序的上传文件接口的注意要点解析
Sep 17 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模块 Memcached功能多于Memcache
2011/06/14 PHP
php的crc32函数使用时需要注意的问题(不然就是坑)
2015/04/21 PHP
PHP内存缓存功能memcached示例
2016/10/19 PHP
tp5(thinkPHP5)框架实现多数据库查询的方法
2019/01/10 PHP
Extjs学习笔记之二 初识Extjs之Form
2010/01/07 Javascript
jquery修改属性值实例代码(设置属性值)
2014/01/06 Javascript
JavaScript中神奇的call()方法
2015/03/12 Javascript
EasyUi中的Combogrid 实现分页和动态搜索远程数据
2016/04/01 Javascript
利用Javascript实现一套自定义事件机制
2017/12/14 Javascript
vue项目中axios使用详解
2018/02/07 Javascript
Layui数据表格之获取表格中所有的数据方法
2018/08/20 Javascript
Vue组件中的data必须是一个function的原因浅析
2018/09/03 Javascript
JavaScript缓动动画函数的封装方法
2020/11/25 Javascript
vue+flask实现视频合成功能(拖拽上传)
2021/03/04 Vue.js
[01:04:06]DOTA2上海特级锦标赛A组资格赛#2 Secret VS EHOME第一局
2016/02/26 DOTA
python通过openpyxl生成Excel文件的方法
2015/05/12 Python
Ubuntu 下 vim 搭建python 环境 配置
2017/06/12 Python
使用python将图片格式转换为ico格式的示例
2018/10/22 Python
python3.6数独问题的解决
2019/01/21 Python
python三大神器之fabric使用教程
2019/06/10 Python
详解Python 调用C# dll库最简方法
2019/06/20 Python
python实现控制COM口的示例
2019/07/03 Python
Python空间数据处理之GDAL读写遥感图像
2019/08/01 Python
css3实现一款模仿iphone样式的注册表单
2013/03/20 HTML / CSS
一级方程式赛车官方网上商店:F1 Store(支持中文)
2018/01/12 全球购物
用C或者C++语言实现SOCKET通信
2015/02/24 面试题
化工专业应届生求职信
2013/11/08 职场文书
消防安全员岗位职责
2014/03/10 职场文书
求职自荐信的格式
2014/04/07 职场文书
医院保洁服务方案
2014/06/11 职场文书
社区两委对照检查材料
2014/08/23 职场文书
高中生旷课检讨书
2014/10/08 职场文书
2015年纪检监察工作总结
2015/04/08 职场文书
小学开学典礼新闻稿
2015/07/17 职场文书
婚宴来宾致辞
2015/07/28 职场文书
SQL 聚合、分组和排序
2021/11/11 MySQL