- 资讯首页 > 开发技术 > web开发 > JavaScript >
- javascript数组includes、reduce的基本使用
在过去的几年中,JavaScript语言进行了多次更新。为了跟上技术更新的脚步,时刻保持一颗学习的心。趁着休息的时间学习熟悉一下数组的includes、reduce的使用。
ES7添加对此方法的支持,includes() 方法用来判断一个数组是否包含一个指定的值的元素,并返回布尔值true或false,如果包含则返回 true,否则返回 false。
arr.includes(valueToFind[, fromIndex])
包含则返回 true,否则返回 false。
// ES5 Code const numbers = ["一", "二", "三", "四"]; console.log(numbers.indexOf("一") > -1); // true console.log(numbers.indexOf("六") > -1); // false // ES7 Code console.log(numbers.includes("一")); // true console.log(numbers.includes("六")); // false console.log(numbers.includes("一",1)); // false,从数组索引为`1`往后找 console.log(numbers.includes("一", -3)); // true,从 `array.length + fromIndex` 的索引开始完后找,跟上面从索引为1开始等效
使用 includes 方法可以使代码简短易懂。include 方法在比较值时也很方便,如下代码。
// 过去 const day = "星期二"; if (day === "星期二" || day === "星期三" || day === "星期四") { console.log(day); } // 现在 if (["星期二", "星期三", "星期四"].includes(day)) { console.log(day); }
reduce() 方法对数组中的每个元素执行reducer函数(升序执行),将其结果汇总为单个返回值。
Array.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])
为数组中的每一个元素依次执行callback函数,不包括数组中被删除或从未被赋值的元素。
函数累计处理的结果。
实例
const arrNumbers = [1, 2, 3, 4, 5]; const reduceNumbers = (arrayNumbers, accumulatorInitVal = false) => { const reduceCallback = (accumulator, currentVal, currentIndex) => { console.log(`当前索引:${currentIndex}`); return accumulator + currentVal; }; return accumulatorInitVal ? arrayNumbers.reduce(reduceCallback, accumulatorInitVal) : arrayNumbers.reduce(reduceCallback); }; console.log(reduceNumbers(arrNumbers)); // 15,累计器初始值为数组的第一个元素的值1 console.log(reduceNumbers(arrNumbers, 10)); // 25,累计器初始值为10
console.log(当前索引:${currentIndex}),是为了更加直观的看到索引值。
第一次未定义初始值输出如下:
当前索引:1
当前索引:2
当前索引:3
当前索引:4
第二次定义了累计器初始值输出如下:
当前索引:0
当前索引:1
当前索引:2
当前索引:3
当前索引:4
接下来我们来看一个奇葩需求,出于某种原因,需要一个包含所有用户全名的新数组(他们的姓,加上他们的名字),但只有当他们是20多岁,并且他们的全名是3个字的时候才需要。不要问我们为什么需要这么奇葩的数据子集,产品经理问了,我们很乐意帮忙^_^
const users = [ { firstName: "坚", lastName: "孙", age: 37, }, { firstName: "策", lastName: "孙", age: 21, }, { firstName: "葛亮", lastName: "诸", age: 28, }, { firstName: "备", lastName: "刘", age: 44, }, { firstName: "统", lastName: "庞", age: 22, }, { firstName: "维", lastName: "姜", age: 19, }, { firstName: "伯温", lastName: "刘", age: 22, }, ]; const getFullName = (user) => `${user.lastName}${user.firstName}`; const filterByAge = (user) => user.age >= 20 && user.age < 30; // 常规实现 const getFilterResult = users // 第一步筛选年龄20-30之间的用户 .filter((user) => filterByAge(user)) // 拼接全名 .map((user) => getFullName(user)) // 筛选 .filter((fullName) => fullName.length === 3); console.log(getFilterResult); // [ '诸葛亮', '刘伯温' ] // 迭代方式实现 const iterationsFilterResult = (arrayResult, currentUser) => { const fullname = getFullName(currentUser); if (filterByAge(currentUser) && fullname.length === 3) { arrayResult.push(fullname); } return arrayResult; }; console.log(users.reduce(iterationsFilterResult, [])); // [ '诸葛亮', '刘伯温' ]
到此这篇关于javascript数组includes、reduce基本使用的文章就介绍到这了,更多相关javascript数组includes、reduce内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
免责声明:本站发布的内容(图片、视频和文字)以原创、来自本网站内容采集于网络互联网转载等其它媒体和分享为主,内容观点不代表本网站立场,如侵犯了原作者的版权,请告知一经查实,将立刻删除涉嫌侵权内容,联系我们QQ:712375056,同时欢迎投稿传递力量。
Copyright © 2009-2022 56dr.com. All Rights Reserved. 特网科技 特网云 版权所有 特网科技 粤ICP备16109289号
域名注册服务机构:阿里云计算有限公司(万网) 域名服务机构:烟台帝思普网络科技有限公司(DNSPod) CDN服务:阿里云计算有限公司 百度云 中国互联网举报中心 增值电信业务经营许可证B2
建议您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流浏览器浏览本网站