首頁  >  文章  >  web前端  >  js實作類似add(1)(2)(3)呼叫方式的方法_javascript技巧

js實作類似add(1)(2)(3)呼叫方式的方法_javascript技巧

WBOY
WBOY原創
2016-05-16 16:11:181255瀏覽

複製程式碼 程式碼如下:

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的值;

以上就是本文的全部內容了,希望大家能夠喜歡。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn