分解多个功能
Factorise multiple functions
也许是愚蠢的问题,但是:
如何分解此类代码?
var rsc = this.checkRsc(path)
if (rsc)
基本上,我想在使用任何方法之前检查事物是否为空。
checkRsc: function(path) {
var rsc = manager.get(path);
if (rsc != undefined)
return rsc;
else
return null;
},
func1: function(path) {
var rsc = this.checkRsc(path)
if (rsc)
this.doStuff(rsc);
},
func2: function(path) {
var rsc = this.checkRsc(path)
if (rsc)
this.doStuffAnotherStuff(rsc);
},
func3: function(path) {
var wave = this.checkRsc(path)
if (wave)
this.andAgain(wave);
},
func4: function(path) {
var rsc = this.checkRsc(path)
if (rsc)
this.AndsomethingElse(rsc);
}
传递要执行的函数,如下所示
checkRsc: function(path, func, context) {
var rsc = manager.get(path);
if (rsc != undefined)
return func.call(context, rsc);
else
return null;
},
然后像这样调用它
this.checkRsc(path, this.doStuff, this)
...
this.checkRsc(path, this.doStuffAnotherStuff, this)
...
this.checkRsc(path, this.andAgain, this)
注意:我也建议传递上下文,因为如果您想在嵌套对象中执行函数,这将派上用场。例如
this.checkRsc(path, this.nested.again, this.nested)
现在
return func.call(context, rsc);
将像这样工作
return [this.nested.again func obj (without context)].call(this.nested, rsc);
相关文章:
- 添加文字和评论功能更新Div
- JavaScript打印功能使日历停止工作
- 每当您在选择器内移动鼠标时,悬停功能就会重复
- 如何防止网页加载后自动启动功能
- 除修剪外的其他功能
- 悬停功能触发器
- 使用angularjs向浏览器发送servlet响应(下载功能)
- 删除CKEditor工具栏按钮,但不删除功能
- 异步facebook功能
- 如何将chrome扩展功能移植到移动设备(特别是jquery和trello)
- jQuery滚动功能只工作一次
- Graphiti中是否有任何工具提示功能
- 重新分解jQuery函数
- React redux初始化功能,无论状态变化如何
- 在哪里可以学习ECMAScript标准中尚未包含的JavaScript功能
- 正在获取select上的功能id
- Rhino打印功能
- 如何分解jQuery"toggle”;函数转换为separate“;显示“;以及“;隐藏“;功能
- 分解多个功能
- 和服:修改数据、分解字符串和添加新属性的功能