JS數(shù)組方法reduce的用法實(shí)例分析
本文實(shí)例講述了JS數(shù)組方法reduce的用法。分享給大家供大家參考,具體如下:
數(shù)組方法 reduce 用來迭代一個(gè)數(shù)組,并且把它累積到一個(gè)值中。
使用 reduce 方法時(shí),你要傳入一個(gè)回調(diào)函數(shù),這個(gè)回調(diào)函數(shù)的參數(shù)是一個(gè) 累加器 (比如例子中的 previousVal) 和當(dāng)前值 (currentVal)。
reduce 方法有一個(gè)可選的第二參數(shù),它可以被用來設(shè)置累加器的初始值。如果沒有在這定義初始值,那么初始值將變成數(shù)組中的第一項(xiàng),而 currentVal 將從數(shù)組的第二項(xiàng)開始。
使用 reduce 方法來讓 array 中的所有值相加
<!DOCTYPE html><html><head><meta charset='utf-8'><title>reduce的使用</title></head><body><script>var arr = [1, 2, 3, 4, 5];sum = arr.reduce(function(prev, cur, index, arr) { //輸出的是第一項(xiàng)的值或上一次疊加的結(jié)果,正在被處理的元素,正在被處理的元素的索引值 console.log(prev, cur, index); return prev + cur;})console.log(arr, sum); //輸入數(shù)組本身和最后的結(jié)果</script></body></html>
控制臺輸出:
var numbers = [15.5, 2.3, 1.1, 4.7]; function getSum(total, num) { return total + Math.round(num);}function myFunction(item) { console.log(numbers.reduce(getSum, 0));//0 傳遞給函數(shù)的初始值}myFunction()//輸出24
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《javascript面向?qū)ο笕腴T教程》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章:
1. python爬蟲實(shí)戰(zhàn)之制作屬于自己的一個(gè)IP代理模塊2. 基于javaweb+jsp實(shí)現(xiàn)企業(yè)財(cái)務(wù)記賬管理系統(tǒng)3. 詳解盒子端CSS動(dòng)畫性能提升4. HTML 絕對路徑與相對路徑概念詳細(xì)5. css代碼優(yōu)化的12個(gè)技巧6. 使用FormData進(jìn)行Ajax請求上傳文件的實(shí)例代碼7. 如何在jsp界面中插入圖片8. .NET6打包部署到Windows Service的全過程9. asp批量添加修改刪除操作示例代碼10. 解決ajax請求后臺,有時(shí)收不到返回值的問題
