js高階函數應用實例map,reduce

'use strict'
/**
 * 聲明一個全局變量
 * @type {{}}
 */
let demo2 = {};
demo2.pow = function (x) {
    return x * x;
}
demo2.moo = function () {
    let arr = [1, 2, 3, 4, 5, 6, 7]
    console.log(arr.map(this.pow));
    console.log(arr.map(String));
}
/**
 * 數組求和
 * @param arr :[1, 2, 3, 4]
 * @returns {number}=>10
 */
demo2.roo = function (arr) {
    return arr.reduce(function (x, y) {
        return x + y;//10
    })
}
/**
 * 數組求積
 * @param arr [1,2,3,4]
 * @returns {*}=>24
 */
demo2.product = function (arr) {
    let r = arr.reduce(function (x, y) {
        return x * y;
    })

    return r;
}
/**
 * 將數組變成數字:
 * @param arr :[1,2,3,4,5]
 * @returns {*} =>12345
 */
demo2.change = function (arr) {
    return arr.reduce(function(x,y){
        return x*10+y;
    })
}
/**
 * 字符串變數字
 * 不使用parseInt() 和Number().混合使用map()和reduce()
 * @param s:"12345"
 * @returns {*} =>12345
 */
demo2.string2int = function (string) {
    let s_arr = string.split('');
    let n_arr = s_arr.map(function (x) {
       return  +x;
    })
    return n_arr.reduce(function (x,y) {
        return x*10+y;
    })
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章