js实现类似于add(1)(2)(3)调用方式的方法
2015-03-04 16:13
519 查看
复制代码 代码如下:
var add = function(a){
return function(b){
return function(c){
return a+b+c;
};
};
};
add(1)(2)(3); //6
function add(x) {
var sum = x;
var tmp = function (y) {
sum = sum + y;
return tmp;
};
tmp.toString = function () {
return sum;
};
return tmp;
}
console.log(add(1)(2)(3)); //6
console.log(add(1)(2)(3)(4)); //10
var add = function(a){
return function(b){
return function(c){
return a+b+c;
};
};
};
add(1)(2)(3); //6
没错!那要是add(1)(2)(3)(4) 这样4个调用呢,那这个肯定不适用了。
这种就是类似于执行一个函数返回函数自身值:
复制代码 代码如下:function add(x) {
var sum = x;
var tmp = function (y) {
sum = sum + y;
return tmp;
};
tmp.toString = function () {
return sum;
};
return tmp;
}
console.log(add(1)(2)(3)); //6
console.log(add(1)(2)(3)(4)); //10
但是在计算完成后还是返回了tmp这个函数,这样就获取不到计算的结果了,我们需要的结果是一个计算的数字那么怎么办呢,首先要知道JavaScript中,打印和相加计算,会分别调用toString或valueOf函数,所以我们重写tmp的toString和valueOf方法,返回sum的值;
以上就是本文的全部内容了,希望大家能够喜欢。
您可能感兴趣的文章:
相关文章推荐
- js实现类似于add(1)(2)(3)调用方式的方法
- js实现类似于add(1)(2)(3)调用方式的通用方法
- js实现类似于add(1)(2)(3)调用方式的方法
- 多种方式实现JS调用后台方法进行数据交互
- 多种方式实现JS调用后台方法进行数据交互
- 多种方式实现JS调用后台方法进行数据交互
- 不用AJAX实现前台JS调用后台C#方法(小技巧) 【改自Web.网际浪人.Blog】
- DedeCMS V5.3实现js调用站外调用的方法
- 不用AJAX实现前台JS调用后台C#方法
- 不用AJAX实现前台JS调用后台C#方法(小技巧) 【改自Web.网际浪人.Blog】
- 改进的“以非泛型方式调用泛型方法”之基于DynamicMethod的实现
- 不用AJAX实现前台JS调用后台C#方法
- .net网站与Winform窗体的数据交互(JS调用Winform后台方法实现)
- 不用AJAX实现前台JS调用后台C#方法(小技巧)
- asp.net下利用JS实现对后台CS代码的调用方法
- js文件中调用js的实现方法小结
- 不用AJAX实现前台JS调用后台C#方法(小技巧) (转)
- 利用sender的Parent获取GridView中的当前行 不用AJAX实现前台JS调用后台C#方法(小技巧) AjaxControlToolkit的CalendarExtender的本地化
- 不用AJAX实现前台JS调用后台C#方法(小技巧)