IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavaScript_数组常用方法( 2 ) -> 正文阅读

[JavaScript知识库]JavaScript_数组常用方法( 2 )

目录

数组常用方法 2?:

1.?forEach( )

forEach?的原理 :

2.?map( )

map?的原理 :

3.?filter(?)

filter 的原理 :

4.?find( )

5.?every(?)

6.?some( )

7.?reduce( )

reduce?原理 :


数组常用方法 2?:

方法2内的数组方法相对复杂一些,?也都不会改变原始数组,?都是以返回值形式给出结果

1.?forEach( )

????????+?语法:?数组.forEach(?function?(item,?index,?arr)?{ }?)

??????????=>?函数可以接受三个参数

??????????=>?第一个参数:?表示数组内的每一项

??????????=>?第二个参数:?表示数组内每一项的索引

??????????=>?第三个参数:?表示原始数组

????????+?作用:?遍历数组

????????+?返回值:?没有?(undefined)

// 1. forEach()
var arr = [10, 20, 30, 40, 50]
console.log(arr)            // [10, 20, 30, 40, 50]
var res = arr.forEach( function a(item, index, arr) {
// 函数 a 会根据 arr 数组中有多少个成员执行多少回
// item, 每一次执行的时候, item 分别是数组内的每一项
// index, 每一次执行的时候, index 分别是数组内每一项的索引
// arr, 每一次执行的时候, arr 都代表原始数组
console.log('我执行了 ', item, ' --- ', index, ' --- ', arr)
} )

?

forEach?的原理 :

????????+?会根据数组内的成员数量分别调用?a?函数

????????+?第一次调用?a(10,?0,?[10,?20,?30,?40,?50])

????????+?第二次调用?a(20,?1,?[10,?20,?30,?40,?50])

????????+?第三次调用?a(30,?2,?[10,?20,?30,?40,?50])

????????+?第四次调用?a(40,?3,?[10,?20,?30,?40,?50])

????????+?第五次调用?a(50,?4,?[10,?20,?30,?40,?50])


?2.?map( )

????+?语法:?数组.map(?function?(item,?index,?arr)?{?}?)

????+?作用:?映射数组

??????=>?对于原始数组里面的数据进行加工处理

??????=>?变成一个新的数组

????+?返回值:?是一个?新数组

??????=>?返回值数组和原始数组必然长度一致

??????=>?新数组内每一个数据都是根据原始数组中每一个数据经过映射加工处理出来的

??????=>?映射加工处理条件以?return?的形式书写

// 2. map()
var arr = [ 10, 20, 30, 40, 50 ]
console.log('原始数组 : ', arr)    // ?[10, 20, 30, 40, 50]
// 开始映射
var res = arr.map(function a(item, index) {
// 书写加工条件
// 以 return 的形式书写映射条件
  return item * (index + 1)
})
console.log('返回值数组 : ', res)  // [10, 40, 90, 160, 250]

map?的原理 :

????????1.?准备一个新数组

??????????=>?[? ]

返回值=>[10,?20,?30,?40,?50]

????????2.?开始根据原始数据进行遍历

??????????=>?第一次调用?a(10,?0,?原始数组),?返回值是?10,?把这个返回值放在新数组里面

??????????=>?第二次调用?a(20,?1,?原始数组),?返回值是 40,?把这个返回值放在新数组里面

??????????=>?第三次调用?a(30,?2,?原始数组),?返回值是 90,?把这个返回值放在新数组里面

??????????=>?第四次调用?a(40, 3,?原始数组),?返回值是 160,?把这个返回值放在新数组里面

??????????=>?第五次调用?a(50, 4,?原始数组),?返回值是 250,?把这个返回值放在新数组里面

??????????=>?...

????????3.?把?最终的这个数组当做?map?这个方法的返回值


3.?filter(?)

????+?语法:?数组.filter(?function?(item,?index,?arr)?{?}?)

????+?作用:?过滤数组 ( 可灵活运用于实现一些"删除"功能 )

??????=>?把原始数组里面满足条件的内容拿出来,?组成一个新的数组

????+?返回值:?是一个 新数组

??????=>?原始数组内有多少满足条件的,?那么新数组里面就有多少个数据

??????=>?原始数组内没有满足条件的,?那么就是?空的数组

??????=>?条件以?return?的形式书写

// 3. filter()
var arr = [ 10, 20, 30, 40, 50 ]
console.log('原始数组 : ', arr)    // [10, 20, 30, 40, 50]
// 对 arr 进行过滤
var res = arr.filter(function a(item) {
// 书写过滤条件
// 以 return 的形式书写过滤条件
  return item / 10 % 2 === 0
})
console.log('返回值数组 : ', res)  // [20, 40]

filter 的原理 :

????????1.?准备一个空数组

??????????=>?[? ]

返回值=>[20, 40]

????????2.?开始根据数组内有多少成员调用多少次?a?函数

??????????=>?第一次调用?a(10,?0,?原始数组),?返回值?false,?那么?10?不加入新数组

??????????=>?第二次调用?a(20,?1,?原始数组),?返回值?true,?那么?20?加入新数组

??????????=>?第三次调用?a(30,?2,?原始数组),?返回值?false,?那么?30?不加入新数组

??????????=>?第四次调用?a(40,?3,?原始数组),?返回值?true,?那么?40?加入新数组

??????????=>?第五次调用?a(50,?4,?原始数组),?返回值 false,?那么?50 不加入新数组

????????3.?把数组最终结果当做?filter?的返回值


?4.?find( )

????+?语法:?数组.find(?function?(item,?index,?arr)?{ }?)

????+?作用:?查找数组中的某一个数据

????+?返回值:?就是数组中你要查找的满足条件的这个数据

????+?查找条件以?return?的形式书写

????+?常用在复杂数据类型的查找

// 4. find()
var arr = [ 100, 200, 301, 400, 500 ]
console.log('原始数组 : ', arr)    // [100, 200, 301, 400, 500]
// 我想找到原始数组中的哪一个 奇数
var res = arr.find(function (item) {
// 以 return 的形式书写查找条件
  return item % 2 === 1
})
console.log('返回值 : ', res)     // 301
// find 一般查找的都是复杂数据类型
var arr = [
  { id: 1, name: 'Jack' },
  { id: 2, name: 'Rose' },
  { id: 3, name: 'Tom' }
]
// 我已知的只有 id, 我想知道这个人叫什么
// 使用 find 方法直接找到这个人的完整信息
var res = arr.find(function (item) {
// 条件: 找到 每一项中 id 是 2 的那一个
  return item.id === 2
})
console.log('返回值数组 : ', res) // {id: 2, name: "Rose"}

? 5.?every(?)

????+?语法:?数组.every(?function?(item,?index,?arr)?{?}?)

????+?作用:?判断数组中的每一个是否都满足条件

????+?返回值:?是一个?布尔值

?????=>?如果数组中每一个都满足条件,?那么返回值?true

?????=>?只要数组中任何一个不满足条件,?那么返回?false

????+?判断条件以?return?的形式书写?

// 5. every()
var arr = [10, 20, 30, 40, 50]
console.log('原始数组 : ', arr) // [10, 20, 30, 40, 50]
var res = arr.every(function (item) {
// 以 return 的形式书写 判断 条件
// 判断数组内是不是所有项都 小于 50
  return item < 50
})
console.log('返回值 : ', res)  // false

6.?some( )

????+?语法:?数组.some(?function?(item,?index,?arr)?{ }?)

????+?作用:?判断数组中是否有某一个满足条件

????+?返回值:?是一个?布尔值

??????=>?如果数组中有任何一个满足条件,?那么返回?true

??????=>?只有数组中所有都不满足条件的时候,?才是?false

// 6. some()
var arr = [10, 20, 30, 40, 50]
console.log('原始数组 : ', arr) // [10, 20, 30, 40, 50]
var res = arr.some(function (item) {
// 以 return 的形式书写 判断 条件
// 判断数组内是不是 有某一个 小于 50
  return item < 50
})
console.log('返回值 : ', res)  // true

7.?reduce( )

????+?语法:?数组.reduce( function?(prev,?item,?index,?arr)?{ },?初始值 )

??????=>?函数,?函数根据数组中的成员进行重复调用

????????->?第一个参数:?初始值?或?每一次叠加后的结果

????????->?第二个参数:?每一项

????????->?第三个参数:?索引

????????->?第四个参数:?原始数组

??????=>?初始值:?默认是?0,?表示从什么位置开始叠加

????+?作用:?进行叠加累计

// 7. reduce( )
var arr = [ 10, 20, 30, 40, 50 ]
console.log('原始数组 : ', arr) // [10, 20, 30, 40, 50]
var res = arr.reduce(function a(prev, item) {
// 以 return 的形式书写每次的叠加条件
  return prev + item
}, 0)
console.log('返回值 : ', res)  // 150

reduce?原理 :

????????1.?准备了一个初始值,?按照你传递的第二个参数来定

??????????=>?准备初始值?var?init?=?0

??????????=>?第一次赋值?var?init?=?10

??????????=>?第二次赋值?var?init?=?30

??????????=>?第三次赋值?var?init?=?60

??????????=>?第四次赋值?var?init?=?100

??????????=>?第五次赋值?var?init?=?150

????????2.?根据原始数组来调用?a?函数

??????????=>?第一次调用?a(0,?10,?0,?原始数组),?return?0?+?10,?把?返回值再次赋值给?init

??????????=>?第二次调用?a(10,?20,?1,?原始数组),?return?10?+?20,?把?返回值再次赋值给?init

??????????=>?第三次调用?a(30,?30,?2,?原始数组),?return?30?+?30,?把?返回值再次赋值给?init

??????????=>?第四次调用?a(60,?40,?3,?原始数组),?return?60?+?40,?把?返回值再次赋值给?init

??????????=>?第五次调用?a(100,?50,?4,?原始数组),?return?100?+?50,?把?返回值再次赋值给?init

????????3.?把最初始准备的变量?init?结果,?当做?reduce?的返回值


上一篇 :?JavaScript_数组-数组常用方法( 1 )?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-13 17:22:27  更:2021-07-13 17:24:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 11:59:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码