数组(array-api)二

forEach( )与map( )

 1     var arr = [5,32,5,7,2,3]
 2     // forEach的时候传递一个函数进来,我们只需要把他写进来,不需要调用
 3     // 这个函数就会被forEach去调用
 4     // arr有多少个元素,函数就会被调用多少遍
 5     // 每一次调用的时候都会传递两个实参过来
 6     // 所以我们要写两个形参,第一个形参是值,第二个形参是索引
 7 
 8     // arr.forEach(function (item, index) {
 9     //   console.log(item, index)
10     // })
11 
12     // 每一次遍历的时候返回一个值,这些值会放进一个新的数组里
13     // map可以用来修改数据,但是不会修改arr本身,而是得到一个新的数组
14     var arr1 = arr.map(function (item, index) {
15       console.log(item, index)
16       return item * (1+0.3)
17     })
18     console.log(arr1)
19 
20     // 只是把索引为奇数的变成1.3倍
21     // 偶数的也得return本身
22     // 每一次都要写返回值,否则新的数组里会有undefined
23     var arr2 = arr.map(function (item, index) {
24       if (index%2) {
25         return item * (1+0.3)
26       }
27       return item
28     })
29     console.log(arr2)

filter()

 1     var arr = [5,7,3,7,3,2]
 2     // 过滤
 3     // 每一次遍历的时候都要返回一个条件(布尔值)
 4     // 当这个条件得结果为true的时候,当前值就会被保留,否则就被过滤掉
 5     // 最终用一个新的数组来存结果
 6 
 7     // 如果不写return,默认返回值是undefined,会隐式转换为false,相当于每次都返回的false
 8     var arr1 = arr.filter(function (item, index) {
 9       console.log(item, index)
10       return item > 4
11     })
12     console.log(arr1)

some()和every()

 1     var arr = [5,2,5,2,6,7]
 2     // some的最终结果是一个布尔值
 3     // 每一次遍历的时候返回一个条件
 4     // 只要在遍历过程中有一条数据满足条件(在所有的返回值当中只要有一个true)
 5     // 整个some的结果就是true
 6     // 在遍历的过程中只要发现了一个true就停止遍历
 7       // var is = arr.some(function (item, index) {
 8       //   console.log(item, index)
 9       //   return item > 10
10       // })
11       // console.log(is)
12 
13     // every 必须每一次遍历返回的条件都是true,结果才为true,否则就是false
14     // 只要任意一个不满足条件,遍历就结束,最终得到false
15     var is = arr.every(function (item, index) {
16       console.log(item, index)
17       return item % 2 === 0
18     })
19     console.log(is)

reduce()

 1     var arr = [3,5,2,6,2]
 2     // current
 3     // 计算arr所有元素的累加和
 4     // 第一次的res是arr[0],以后的res是上一次的返回值
 5     // var sum = arr.reduce(function (res, curr, index) {
 6     //   // index是curr的索引,默认从1开始,但是一般用的不多
 7     //   console.log(res, curr, index)
 8     //   return res + curr
 9     // })
10     // console.log(sum)
11 
12     
13     // reduce有两个参数,第一个参数是函数,第二个参数可选的默认值
14     // 在后面写上一个默认值,循环次数就跟数组长度相等,res默认值就是1,curr从arr[0]开始
15     var sum = arr.reduce(function (res, curr, index) {
16       console.log(res, curr, index)
17       // res *= curr
18       // return res
19       return res *curr
20     }, 1)
21     console.log(sum)
22 
23    //二维数组归并为一维数组 
24    var arr = [
25       [1,2,3],
26       [4,5,6],
27       [7,8,9]
28     ]
29 
30     var arr1 = arr.reduce(function (res, curr) {
31       return res.concat(curr)
32     }, [])
33 
34     console.log(arr1)
35 
36 
37     var arr = [
38       [1,2,3],
39       [4,5,6],
40       [7,8,9]
41     ]
42 
43     // reduce是从左往右归并,reduceRight从右往左
44     // reduceRight的语法和reduce是完全一样的
45     var arr1 = arr.reduceRight(function (res, curr) {
46       return res.concat(curr)
47     }, [])
48 
49     console.log(arr1) // [7,8,9,4,5,6,1,2,3]

 

posted @ 2020-04-12 17:14  strongerPian  阅读(130)  评论(0编辑  收藏  举报
返回顶端