电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

js 數組 find,some,filter,reduce區別詳解

瀏覽:87日期:2024-03-22 15:31:44

區分清楚Array中filter、find、some、reduce這幾個方法的區別,根據它們的使用場景更好的應用在日常編碼中。

Array.find

Array.find 返回一個對象(第一個滿足條件的對象)后停止遍歷

const arrTest = [ { id: 1, name: 'a' }, { id: 2, name: 'b' }, { id: 3, name: 'b' }, { id: 4, name: 'c' }]// 過濾條件function getName(val) { return arrTest => arrTest.name === val}

// 如果我們是想找到第一個滿足條件的數據,應該使用`Array.find`console.log(arrTest.find(getName('b')))// { id: 2, name: 'b' }Array.some

Array.some 返回是否滿足條件的布爾值

const arrTest = [ { id: 1, name: 'a', status: 'loading' }, { id: 2, name: 'b', status: 'loading' }, { id: 3, name: 'b', status: 'success' }]// 過濾條件function getStatus(val) { return arrTest => arrTest.status === val}

// 如果我們需要查找一個數組中是否存在某個數據的時候,使用Array.some直接拿到結果console.log(arrTest.some(getStatus('success')))// trueArray.filter

Array.filter 遍歷整個Array返回一個數組(包含所有滿足條件的對象)

const arrTest = [ { id: 1, name: 'a', status: 'loading' }, { id: 2, name: 'b', status: 'loading' }, { id: 3, name: 'b', status: 'success' }]// 過濾條件function getStatus(val) { return arrTest => arrTest.status === val} // 如果我們是需要過濾出一個數組中所有滿足條件的數據,應該使用Array.filterconsole.log(arrTest.filter(getStatus('loading')))// [// { id: 1, name: 'a', status: 'loading' },// { id: 2, name: 'b', status: 'loading' }// ]Array.reduce

Array.reduce 為數組的歸并方法,使用場景很多,比如求和、求乘積,計次,去重,多維轉一維,屬性求和等...本節示例主要實現Array.reduce對一組數據進行條件過濾后,返回一個新的數組

const arrTest = [ { id: 1, status: 'loading' }, { id: 2, status: 'loading' }, { id: 3, status: 'success' }]console.log( arrTest.reduce((acc, character) => {return character.status === 'loading' ? acc.concat( Object.assign({}, character, { color: 'info' }) ) : acc }, []))// [// { id: 1, status: 'loading', color: 'info' },// { id: 2, status: 'loading', color: 'info' }// ]

與Array.filter返回的數組的不同,filter返回的是原數組中符合條件的對象集合,filter與 Array.map 結合也可以實現上面的結果,為什么使用reduce更好呢?

// Array.map 和 Array.filter 組合console.log( arrTest.filter(character => character.status === 'loading').map(character => Object.assign({}, character, { color: 'info' })))// [// { id: 1, status: 'loading', color: 'info' },// { id: 2, status: 'loading', color: 'info' }// ]

結論:同時使用 Array.filter 和 Array.map 的時候,對整個數組循環了 2 遍。第一次是過濾返回一個新的數組,第二次通過 map 又構造一個新的數組。使用了兩個數組方法,每一個方法都有各自的回調函數,而且 filter 返回的數組以后再也不會用到。使用 Array.reduce 同樣的結果,代碼更優雅。

到此這篇關于js 數組 find,some,filter,reduce區別詳解的文章就介紹到這了,更多相關js 數組 find,some,filter,reduce內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 书法培训-高考书法艺考培训班-山东艺霖书法培训凭实力挺进央美 | 防腐木批发价格_深圳_惠州_东莞防腐木厂家_森源(深圳)防腐木有限公司 | 智慧物联网行业一站式解决方案提供商-北京东成基业 | 铁艺,仿竹,竹节,护栏,围栏,篱笆,栅栏,栏杆,护栏网,网围栏,厂家 - 河北稳重金属丝网制品有限公司 山东太阳能路灯厂家-庭院灯生产厂家-济南晟启灯饰有限公司 | 电动垃圾车,垃圾清运车-江苏速利达机车有限公司 | 不锈钢复合板厂家_钛钢复合板批发_铜铝复合板供应-威海泓方金属复合材料股份有限公司 | 防水试验机_防水测试设备_防水试验装置_淋雨试验箱-广州岳信试验设备有限公司 | 挤塑板-XPS挤塑板-挤塑板设备厂家[襄阳欧格] | 临时厕所租赁_玻璃钢厕所租赁_蹲式|坐式厕所出租-北京慧海通 | 免费分销系统 — 分销商城系统_分销小程序开发 -【微商来】 | 不锈钢发酵罐_水果酒发酵罐_谷物发酵罐_山东誉诚不锈钢制品有限公司 | 不锈钢反应釜,不锈钢反应釜厂家-价格-威海鑫泰化工机械有限公司 不干胶标签-不干胶贴纸-不干胶标签定制-不干胶标签印刷厂-弗雷曼纸业(苏州)有限公司 | 防堵吹扫装置-防堵风压测量装置-电动操作显示器-兴洲仪器 | 玻璃钢格栅盖板|玻璃钢盖板|玻璃钢格栅板|树篦子-长沙川皖玻璃钢制品有限公司 | 噪声治理公司-噪音治理专业隔音降噪公司 | 电缆隧道在线监测-智慧配电站房-升压站在线监测-江苏久创电气科技有限公司 | 上海刑事律师|刑事辩护律师|专业刑事犯罪辩护律师免费咨询-[尤辰荣]金牌上海刑事律师团队 | 合肥通道闸-安徽车牌识别-人脸识别系统厂家-安徽熵控智能技术有限公司 | 桐城新闻网—桐城市融媒体中心主办 | 超细|超微气流粉碎机|气流磨|气流分级机|粉体改性机|磨粉机|粉碎设备-山东埃尔派粉体科技 | 工业洗衣机_工业洗涤设备_上海力净工业洗衣机厂家-洗涤设备首页 bkzzy在职研究生网 - 在职研究生招生信息咨询平台 | 百度爱采购运营研究社社群-店铺托管-爱采购代运营-良言多米网络公司 | 奥运星-汽车性能网评-提供个性化汽车资讯 | 东莞ERP软件_广州云ERP_中山ERP_台湾工厂erp系统-广东顺景软件科技有限公司 | 铝扣板-铝方通-铝格栅-铝条扣板-铝单板幕墙-佳得利吊顶天花厂家 elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 找培训机构_找学习课程_励普教育 | 技德应用| POS机官网 - 拉卡拉POS机免费办理|官网在线申请入口 | Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | 基业箱_环网柜_配电柜厂家_开关柜厂家_开关断路器-东莞基业电气设备有限公司 | 集装箱标准养护室-集装箱移动式养护室-广州璟业试验仪器有限公司 | 不锈钢列管式冷凝器,换热器厂家-无锡飞尔诺环境工程有限公司 | 大连海岛旅游网>>大连旅游,大连海岛游,旅游景点攻略,海岛旅游官网 | 成都顶呱呱信息技术有限公司-贷款_个人贷款_银行贷款在线申请 - 成都贷款公司 | 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 粤丰硕水性环氧地坪漆-防静电自流平厂家-环保地坪涂料代理 | 山东限矩型液力偶合器_液力耦合器易熔塞厂家-淄博市汇川源机械厂 | 诚暄电子公司首页-线路板打样,pcb线路板打样加工制作厂家 | 特种电缆厂家-硅橡胶耐高温电缆-耐低温补偿导线-安徽万邦特种电缆有限公司 | 河南道路标志牌_交通路标牌_交通标志牌厂家-郑州路畅交通 | 中山市派格家具有限公司【官网】|