面试题JS的一些优雅写法 reduce和map
Posted 前端技术栈
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了面试题JS的一些优雅写法 reduce和map相关的知识,希望对你有一定的参考价值。
大厂面试题分享 面试题库
前后端面试题库 (面试必备) 推荐:★★★★★
地址:前端面试题库 web前端面试题库 VS java后端面试题库大全
JS的一些优雅写法
reduce
1、可以使用 reduce 方法来实现对象数组中根据某一key值求和
例如,假设有以下对象数组:
const arr = [
name: 'apple', price: 2 ,
name: 'banana', price: 3 ,
name: 'orange', price: 4 ,
];
复制代码
如果要根据price属性求和,可以使用以下代码:
const sum = arr.reduce((acc, cur) => acc + cur.price, 0);
console.log(sum); // 9
复制代码
其中,reduce方法的第一个参数是一个回调函数,它接收两个参数:累加器(acc)和当前元素(cur)。回调函数的返回值会作为下一次调用回调函数时的累加器的值。reduce方法的第二个参数是累加器的初始值,这里设置为0。
在回调函数中,我们将累加器和当前元素的price属性相加,最终得到了所有元素的price属性的总和。
map
1、可以使用map方法来实现对象数组中根据某一key值,取得另外一个key的值。
例如,假设有以下对象数组:
const arr = [
name: 'apple', price: 2 ,
name: 'banana', price: 3 ,
name: 'orange', price: 4 ,
];
复制代码
如果要根据name属性获取price属性,可以使用以下代码:
const prices = arr.map(item => item.name === 'banana' ? item.price : null);
console.log(prices); // [null, 3, null]
复制代码
其中,map方法的参数是一个回调函数,它接收一个参数:当前元素(item)。回调函数的返回值会作为新数组的元素。在回调函数中,我们判断当前元素的name属性是否等于'banana',如果是,则返回当前元素的price属性,否则返回null。最终得到了一个新数组,其中只有name属性为'banana'的元素的price属性有值,其他元素的price属性为null。
2、可以使用map方法来获取对象数组中根据某一key值得到的元素的price属性,可以使用find方法来实现。
例如,假设有以下对象数组:
const arr = [
name: 'apple', price: 2 ,
name: 'banana', price: 3 ,
name: 'orange', price: 4 ,
];
复制代码
如果要根据name属性获取price属性,可以使用以下代码:
const banana = arr.find(item => item.name === 'banana');
if (banana)
console.log(banana.price); // 3
复制代码
其中,find方法的参数是一个回调函数,它接收一个参数:当前元素(item)。回调函数需要返回一个布尔值,表示当前元素是否符合条件。find方法会返回符合条件的第一个元素,如果没有符合条件的元素,则返回undefined。
在回调函数中,我们判断当前元素是否banana,如果是,则返回当前元素。最终得到了一个对象,其中只有name属性为'banana'的元素的price属性有值,其他元素price属性为undefined。我们可以使用if语句来判断是否找到了符合条件的元素,如果找到了,则输出它的price属性。
大厂面试题分享 面试题库
前后端面试题库 (面试必备) 推荐:★★★★★
地址:前端面试题库 web前端面试题库 VS java后端面试题库大全
今日头条上看到的js面试题和答案
用js判断字符中每个字符出现的次数,
答案是var info = arr.split(‘‘).reduce((a,b)=>(console.log(a,b),a[b]++ || (a[b]=1),a),{});
这里面运用到了es5,6的reduce和箭头函数,琢磨半天才明白,把箭头函数简化成普通函数可以写成这样
var info = arr.split(‘‘).reduce(function(a,b){ if(a[b]){ a[b]++ ; }else{ a[b]=1; } return a; },{});
以上是关于面试题JS的一些优雅写法 reduce和map的主要内容,如果未能解决你的问题,请参考以下文章