数组的类
  数组的类是Array
数组的定义
  var arr=[元素]
  var arr=new Array(3) 数字3,代表有三个元素或者三个空位
  如果数组定义采用 new 实例,类中跟的是一个数字 n ,代表有 n 个元素
  var arr=new Array("6") 有一个元素,并且这个元素是6
数组的方法
of 方法
  1. Array 类上的方法
  2. var arr=Array.of(4);console.log(arr); //4 返回一个元素为4的数组
 
 
foreach 方法
  1. 原型上的一个方法,用于对数组遍历,返回值是undefined
  2. var arr = ["xiaopang", "xiaohe", "xiaoxin"];
  arr.forEach((item,index)=>{
    console.log(index)
  })
  3. foreach 没有返回值
 
 map 方法
  1. 遍历数组(原型上的一个方法,返回值是一个数组,所以必须加 return 返回值),将数组一一映射成一个新的数组,内部一定要使用return
  2. var arr = ["xiaopang", "xiaohe", "xiaoxin"];
  var as=arr.map((item,index)=>{
  return item+"123"
  })
  console.log(as)
 
filter 方法
  1. 过滤 从数组中找出所有符合条件的元素,并返回一个新的数组,不改变原有数组
  2. return true 就保留原来的数组,return false 就不保留
  3. 当return 的条件成立就是 true ,不成立就是 false
  4. var arr=[
  {"name":"xiaopang","age":10},
  {"name":"xiaohe","age":20},
  {"name":"xiaoxin","age":25},
  {"name":"pangpang","age":13}
  ]
  var as=arr.filter((item,index)=>{
    return item.age>13
  })
  console.log(as)
  5. var as=arr.filter((item,index)=>{
    return item.age>13
  })
  console.log(as)
  数组里有符合条件的,所以是 true ,所以返回符合条件的新数组
 
find 方法
  1. 对数组逐个查找,当返回值为 true 说明查找到,直接返回结果,不再往下查找了
  2. var as=arr.find((item,index)=>{
    return item.age>13
  })
  console.log(as)
 
every 方法
  1. 看数组中的每个元素是否都满足条件,都满足条件返回的是 true,如果有一个不满足,返回值就是 false
  2. var arr=[
  {"name":"xiaopang","age":10},
  {"name":"xiaohe","age":20},
  {"name":"xiaoxin","age":25},
  {"name":"pangpang","age":13}
  ]
  var as=arr.every((item,index)=>{
  return item.age<=13
  })
  console.log(as)
 
some 方法
  1. 看数组中的元素,是否有满足条件的,有就true ,没有 就是false
  2. var arr=[
  {"name":"xiaopang","age":10},
  {"name":"xiaohe","age":20},
  {"name":"xiaoxin","age":25},
  {"name":"pangpang","age":13}
  ]
  var as=arr.some((item,index)=>{
  return item.age<=13
  })
  console.log(as)
 
reduce 方法
  1. 迭代执行
  2. var arr=[1,2,3,4,5,6,7,8,9,10];
  var as=arr.reduce((prev,item)=>{
  // prev 航一次返回值
  // item 数组的元素,从第二个开始
  console.log(prev);
    return prev+item;
  })
  console.log(as) //55
  3. 注意: 1.从第二个元素开始执行,因为第一个元素没有上一个
  2.第一次执行的返回的是第一个元素 reduce() 的参数是一个回调函数,回调函数中可以放三个参数,第一个 prev 代表上一次执行后的返回值,第二个 item 当前元素,第三个 index 索引值
  3. 如果想让 reduce 从第一个元素开始执行 (默认为第二个),可以在回调函数之后加一个参数,就可以让初始有个默认值
 
面试题
将一个数组转换成对象,属性是数组的元素,属性值是元素的个数
    解答;
      var arr=["item","tom",,"jack","item","jack"];
      var as=arr.reduce((prev,item)=>{
        if(item in prev){
          prev[item]++
        }
        else{
          prev[item]=1;
        }
        return prev
      },{})
      console.log(as);

ES6 数组的方法的更多相关文章

  1. JavaScript ES6 数组新方法 学习随笔

    JavaScript ES6 数组新方法 学习随笔 新建数组 var arr = [1, 2, 2, 3, 4] includes 方法 includes 查找数组有无该参数 有返回true var ...

  2. ES6 数组遍历方法的实战用法总结(forEach,every,some,map,filter,reduce,reduceRight,indexOf,lastIndexOf)

    目录 forEach every some map filter reduce && reduceRight indexOf lastIndexOf 前言 ES6原生语法中提供了非常多 ...

  3. es6数组的方法

    1.复习的函数 函数是由关键字function声明的,他是一个引用数据类型,是Function的实例,在调用的时候会开辟一个私有空间 2.函数的成员 arguments:null  (是实参构成的数组 ...

  4. ES6数组去重方法

    Set实例的方法分为两大类:操作方法(用于操作数据)和遍历方法(用于遍历成员),操作方法有:add(value).delete(value).has(value).clear():遍历方法有:keys ...

  5. es6 数组扩展方法

    1.扩展运算符 含义: 扩展运算符,三个点(...),将一个数组转为用逗号分隔的参数顺序. 例如: console.log([1,2,3]); console.log(...[1,2,3]);   结 ...

  6. es6数组新方法

    (1)Array.from(aarr,fn,obj) function fn(dr, sd, d) { /*Array.from 类数组转化为数组*/ console.log(arguments) v ...

  7. es6 数组新增方法

    1.Array.from(): 这个函数的作用是将类似数组的对象转化为数组,比如DOM对象 let arrayLike = {      "0":"TangSir&quo ...

  8. ES6数组新增方法总结

    关于数组中forEach() .map().filter().reduce().some().every()的总结 let arr = [1, 2, 3, 4, 5] // forEach遍历数组 a ...

  9. ES6 数组去重 方法用了filter或者 indexOf Array.from

随机推荐

  1. NPM包管理器入门(附加cnpm : 无法加载文件错误解决方案)

    NPM 包管理器 1.作用: 快速构建nodejs工程 快速安装和依赖第三个模块 2.使用方法 快速构建 npm init 会得到一package.json文件 { "name": ...

  2. 解决nohup: 忽略输入并把输出追加到"nohup.out"或者nohup: 忽略输入重定向错误到标准输出端

    nohup启动脚本的时候,没有指定输出路径,默认使用当前目录的nohup.out 例如下面这句就是默认使用nohup.out作为输出文件: nohup script.sh & 改成下面的,则/ ...

  3. 在 Linux 中,最直观、最可见的部分就是 文件系统(file system)

    在 Linux 中,最直观.最可见的部分就是 文件系统(file system).下面我们就来一起探讨一下关于 Linux 中国的文件系统,系统调用以及文件系统实现背后的原理和思想.这些思想中有一些来 ...

  4. $(cd "$(dirname "$0")",pwd) 解析

    xx.sh 文件内容如下: #!/bin/bash BIN_FOLDER=$(cd "$(dirname "$0")";pwd) echo $BIN_FOLDE ...

  5. 如何解决在WordPress安装Redis插件时需要输入FTP问题?

    用LAMP或者LNMP搭建Worepress的时候,安装主题或者插件时候,往往提示需要输入FTP服务端信息的问题,其实这是一个坑,可以完全避免的 我们只需在wp-config.php文件最后添加以下代 ...

  6. python3 访问windows共享目录

    python3 访问windows共享目录 1.安装pysmb包 pip install pysmb 2.连接共享目录 #!/usr/bin/env python3 # -*- coding:utf- ...

  7. 【错误解决】Error creating bean with name 'transactionManager' :nested exception is java.lang.NoClassDefFoundError: org/springframework/jdbc/datasource/

    搭建ssh框架中新建JUint测试出现的问题.这个问题实在太伤脑筋....因为不好找到解决办法 直接先说解决方式:添加org.springframework.jdbc-XX.jar,然后build p ...

  8. log4j 日志文件(Day_19)

    详细  :   https://www.cnblogs.com/liaojie970/p/7634838.html log4j  日志文件 1 log4j.rootLogger=debug,CONSO ...

  9. Go语言之main包

    Go语言的代码通过包(package)组织,包类似于其他语言里的库(libraries)或者模块(modules).一个包由位于单个目录下的一个或多个go源文件组成,目录定义包的作用.每个源文件都以一 ...

  10. 20192113 2020-2021-2 《Python程序设计》实验二报告

    20192113 2020-2021-2 <Python程序设计>实验二报告 课程:<Python程序设计> 班级: 1921 姓名: 衣丽莎 学号:20192113 实验教师 ...