中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript數組reduce()方法怎么用

發布時間:2022-01-12 17:43:07 來源:億速云 閱讀:137 作者:iii 欄目:開發技術

本篇內容主要講解“JavaScript數組reduce()方法怎么用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“JavaScript數組reduce()方法怎么用”吧!

將某個值減去數組中的每個元素:

var items = [5, 10, 15];
var reducer = function minus(minusSum, item) {
    return minusSum - item;
}
var total = items.reduce(reducer, 61);
console.log(total); // 31

上例中初始值為number類型,所以返回的結果也是number類型的,如果我們想返回object類型的值,也可以傳入object類型的初始值。

var items = [5, 10, 15];
var reducer = function minus(minusSum, item) {
    minusSum.sum = minusSum.sum - item;
    return minusSum;
}
var total = items.reduce(reducer, {sum: 61});
console.log(total); // {sum: 31}

以上兩例都是reduce()簡單的用法。reduce()是一個很強大的方法,我們還可以用它來處理更復雜的業務邏輯。

例如,求購物車中商品的總價,購物車數據如下:

var goodList = [
    {
        good: 'paper',
        price: 12
    },
    {
        good: 'book',
        price: 58
    },
    {
        good: 'CD',
        price: 15
    }       
]

然后運用reduce()方法可以輕松的獲得所有商品的總價格:

var count = goodList.reduce(function(prev, cur) {
    return cur.price + prev;
}, 0);
console.log(count); // 85

如果用戶有10元的優惠券的話,我們只需要將 -10作為初始值傳入reduce()方法中就可以了。

var count = goodList.reduce(function(prev, cur) {
    return cur.price + prev;
}, -10);
console.log(count); // 75

我們給例子增加一點難度,商城在搞促銷,對商品有一定的折扣,我們應該如何求得商品的總價格呢?利用reduce方法也可以很容易解決的。

var goodList = [
    {
        good: 'paper',
        price: 12
    },
    {
        good: 'book',
        price: 58
    },
    {
        good: 'CD',
        price: 15
    }       
];

var dis = {
    paper: 0.5,
    book: 0.8,
    CD: 0.2
}

var count = goodList.reduce(function(prev, cur) {
    return cur.price + prev;
}, -10);

var qcount = goodList.reduce(function(prev, cur) {
    return cur.price * dis[cur.good] + prev;
}, 0);

console.log(count, qcount); // 75 55.400000000000006

我們這里就忽略JS中的精度問題吧,因為這里主要講解reduce()方法的用法。
再舉一個例子,如何求得一串字符串中每個字母出現的次數?如果我們不用reduce()方法也可以實現的,

代碼如下:

var arrString = 'fghffgaga';
var strArr = arrString.split('');
var rel = {};
var count = 1;
for (var i = 0; i < strArr.length; i++) {
    for (var j = i + 1; j < strArr.length; j++) {
        if (strArr[i] == strArr[j]) {
            count++;
            strArr.splice(j, 1);
            j = j - 1;              
        }

    }
    var qcount = count;
    count = 1;
    rel[strArr[i]] = qcount;    
}
console.log(rel); // {f: 3, g: 3, h: 1, a: 2}

利用reduce()方法的代碼如下:

var arrString = 'fghffgaga';
var rel = arrString.split('').reduce(function(res, cur) {
  res[cur] ? res[cur] ++ : res[cur] = 1
  return res;
}, {})
console.log(rel); // {f: 3, g: 3, h: 1, a: 2}

哈哈,利用reduce()方法來處理的話,代碼是不是簡單了很多?
我們可以用reduce()方法來對數組中的每個元素來做各種處理,將一種類型的數組轉換成另一種類型的數組。

var arr = [1, 2].reduce(function(res, cur) { 
  res.push(cur + ''); 
  return res; 
}, []);
console.log(arr); // ["1", "2"]

到此,相信大家對“JavaScript數組reduce()方法怎么用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

舞阳县| 五原县| 彭水| 阿克苏市| 宁蒗| 富宁县| 仪陇县| 东城区| 赤水市| 襄垣县| 彝良县| 花莲县| 天长市| 荣昌县| 黄龙县| 武乡县| 九台市| 玉山县| 嘉鱼县| 确山县| 宾阳县| 隆安县| 清远市| 罗山县| 政和县| 山阴县| 乐都县| 来凤县| 台前县| 灌云县| 共和县| 罗源县| 禄劝| 蓬安县| 石楼县| 东乌| 双牌县| 安图县| 玉林市| 康平县| 南华县|