Javascript:forEach、map、filter、reduce、reduceRight

简介: Javascript:forEach、map、filter、reduce、reduceRight

正文

filter的使用

====================================================================

会过滤原数组,返回一个新的数组,过滤条件由filter中表达式决定

基础使用语法:

let array5 = array4.filter(value => 条件)

举例:

let array4 = [1, 2, 3, 4, 5, 6];
let array5 = array4.filter(value => value % 2 === 0)
console.log(array4)
console.log(array5)

运行结果:

reduce和reduceRight的使用

================================================================================

按照条件对原数组进行操作。

比如对原数组进行求和(求积),或在某数基础上对某一数组进行求和(求积)

基础使用语法:

let result = array6.reduce(函数,初始值,初始值下标,初始值下标数组)

举例:

let array6 = [1, 2, 3, 4];
function getSum(total, num) {
return total + num;
}
let result1 = array6.reduce(getSum);
let result2 = array6.reduce(getSum, 3);
let result3 = array6.reduce(getSum, 1, [1, 2, 3]);
console.log(result1, result2, result3);

运行结果:

reduceRight()方法的功能和reduce()功能是一样的,不同的是reduceRight()从数组的末尾向前将数组中的数组项做操作。

运算条件:求todo中finished为true的数据个数

finishedCount() {
return this.todos.reduce((total, todo) => total + (todo.finished ? 1 : 0), 0)
}

find和findIndex的使用

============================================================================

find:查询数组中第一个满足某条件的值

findIndex:查询数组中第一个满足某条件的值的下标

基础使用语法:

array7.find((value => 条件))

array7.findIndex((value => 条件))

举例:

let array7 = [
{name:‘1’,sex:‘女’,age:1},
{name:‘2’,sex:‘女’,age:2},
{name:‘3’,sex:‘女’,age:3},
{name:‘4’,sex:‘女’,age:4},
];
console.log(array7.find((value => value.name===‘4’)))
console.log(array7.findIndex((value => value.name===‘4’)))

运行结果:

keys,values,entries的使用

=================================================================================

ES6 提供三个新的方法 —— entries(),keys()和values() —— 用于遍历数组。它们都返回一个遍历器对象,可以用for…of循环进行遍历,唯一的区别是keys()是对键名的遍历、values()是对键值的遍历,entries()是对键值对的遍历

基础使用语法:

for(let index of 数组.keys()){
console.log(index) // 输出下标
}
for(let elem of 数组.values()){
console.log(elem) // 输出值
}
for(let [index,elem] of 数组.entries()){
console.log(index,elem) // 输出值和下标
}
举例:
let array8 = [1, 2, 3];
for(let index of array8.keys()){
console.log(index)
}
for(let elem of array8.values()){
console.log(elem)
}
for(let [index,elem] of array8.entries()){
console.log(index,elem)
}
总结一下

面试前要精心做好准备,简历上写的知识点和原理都需要准备好,项目上多想想难点和亮点,这是面试时能和别人不一样的地方。

还有就是表现出自己的谦虚好学,以及对于未来持续进阶的规划,企业招人更偏爱稳定的人。

万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。

为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。

前端面试题汇总


目录
打赏
0
0
0
0
80
分享
相关文章
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
JavaScript 数组常用高阶函数总结,包括插入,删除,更新,反转,排序等,如map、splice等
JavaScript数组的常用高阶函数,包括遍历、插入、删除、更新、反转和排序等操作,如map、splice、push、pop、reverse等。
43 0
问js的forEach和map的区别
JavaScript中的`forEach`和`map`都是数组迭代方法。`forEach`遍历数组但不修改原数组,无返回值;它接受回调函数处理元素。`map`则遍历数组并返回新数组,新数组元素为回调函数处理后的结果。两者都接收元素、索引和数组作为回调函数参数。
76 7
面试题:问js的forEach和map的区别
面试题:问js的forEach和map的区别
浅谈 Javascript 中的 forEach 和 map 之间的区别
在 Javascript 中数组的迭代最常用的两个函数:forEach和map。可能很多人认为这两个函数在工作方式上是相同的,它们都进行迭代并输出数组的每一项。本文就来介绍一下forEach和map的差异,并因此加深对两个函数的理解。
180 0
浅谈 Javascript 中的 forEach 和 map 之间的区别
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
61 1
JavaScript中的原型 保姆级文章一文搞懂
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
153 2
|
5月前
JS+CSS3文章内容背景黑白切换源码
JS+CSS3文章内容背景黑白切换源码是一款基于JS+CSS3制作的简单网页文章文字内容背景颜色黑白切换效果。
40 0
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
225 5

热门文章

最新文章