1.判断是否是数组 Array.isArray( arg ) 有兼容性

2.toString 数组转字符串 arr.toString();

3.join 数组每一项间的拼接 arr.join(); String.split()

4.pop 删除原数组最后一项,返回删除项 arr.pop() 原数组被修改

5.push 在原数组末尾添加一项,返回数组新长度,改变原数组
  arr.push( ...arg )

6.shift 删除数组第一项,改变原数组,返回删除项
  arr.shift( );

7.unshift 在原数组首位添加项,返回数组新长度
  arr.unshift( ...arg );

8.reverse 反转数组项的顺序,返回修改后的数组
  arr.reverse();

9.sort 数组每项按照unicode编码排序,默认升序
  arr.sort();

10.concat 数组合并,返回合并后的数组   arr1.concat( arr2 )

11.slice 截取数组 参数一:开始位置 参数二:结束位置后一位
      参数为负数,用数组总长度加上该负数来确定位置;
   结束位置小于起始位置,返回空数组
  arr.slice(arg1,arg2)

12.splice 删除、插入、替换数组元素
  参数一:起始位置 参数二:删除元素个数 参数三:插入的元素
  arr.splice(arg1,arg2,arg3)

  返回被删除的项,会改变原数组。

13.indexOf/lastIndexOf 数组中查找元素的位置
  参数一:要查找的元素 参数二:开始查找位置 返回值-1 不存在,返回值大于等于0表示元素位置
  arr.indexOf(arg1,arg2) 从左往右查找
  arr.lastIndexOf(arg1,arg2) 从右往左查找

遍历数组的5种方法

14.every 数组的每一项都返回true,遍历完整个数组,最终返回值才为true
  arr.every((val,index,arr)=>{
    return val<10;
  })

15.some 数组任意一项返回true,则停止遍历,返回值为true

  arr.some((val,index,arr)=>{
    return val<10;
  })

16.filter 遍历整个数组,找到符合的元素,返回这个新组成的数组
  arr.filter((val,index,arr)=>{
    return val<10;
  })

17.map 遍历整个数组,返回每个元素调用后的结果组成新的数组
  arr.map((val,index,arr)=>{
    return val**2;
  })

18.forEach 遍历数组每一项
  arr.foreach((val,index,arr)=>{
    return val**2;
   })

19.数组累加器reduce、reduceRight
  arr.reduce((preValue, currentValue)=>{
    return preValue + currentValue
  })

ES6新增数组方法

20.from 将类似数组的对象和可遍历的对象转为真正的数组。
  Array.from(["a","b","c"])
  Array.from("fool")

21.of 将一组值转为数组 弥补Array()的不足
  Array.of(7) //[,,,,,,]
  Array.of(7) // [7]
  Array.of(1, 2, 3); // [1, 2, 3]

22.copyWithin 将数组中指定位置的元素复制到其他位置(会覆盖掉原有元素)
  参数一:从该位置开始替换元素 参数二:从该位置开始读取数据,默认为0 参数三:到该位置停止读 取数据,默认为数组长度
  arr.copyWithin(arg1,arg2,arg3)

23.fill 使用给定值,填充数组 参数一:给定的值 参数二:起始位置 参数三:结束位置
  arr.fill(arg1,arg2,arg3)

24.find/findIndex 找到数组中符合条件的值/位置,若没找到返回undefined
  arr.find((val,index,arr)=>{
    return val>9;
  })

25.keys() 遍历数组获取键名
    values() 遍历数组获取键值
    entries() 遍历数组获取键值对
  for(let [index,val] of arr.keys()) {
    console.log(val)
  }

ES7.0新增的数组方法

26.includes 判断数组中是否存在该元素 弥补indexOf不能判断NaN
  arr.includes()

ES8没有新增数组方法

ES5-ES8 数组拥有的方法的更多相关文章

  1. ES5中数组新增的方法说明

    一.前言-索引 ES5中新增的不少东西,了解之对我们写JavaScript会有不少帮助,比如数组这块,我们可能就不需要去有板有眼地for循环了. ES5中新增了写数组方法,如forEach (js v ...

  2. 关于 ES5 & ES6 数组遍历的方法

    ES5 数组遍历方法 1.for 循环 , , , , ] ; i < arr.length; i++) { console.log(arr[i]) } 2.forEach , , , , ] ...

  3. ES5新增数组的一些方法

    1.Array.indexof(value1,value2) Tip:用于返回某个数组或字符串中规定字符或者字符串的位置. (1)当Array.indexof(value1);里面只有一个值的时候,表 ...

  4. es5中数组的遍历方法

    //for循环 const arr = [1,2,3,4,5] for(let i = 0; i < arr.length; i++){ if(arr[i] === 2){ //break // ...

  5. ES5 对数组方法的扩展 以及 正则表达式

    ES5 对数组的扩展 forEach map some every indexOf lastIndexOf forEach 与 map 语法: 数组.forEach(function ( v, i ) ...

  6. 4日6日--ES5新增数组方法

    forEach使用的函数调用,所以占内存比较大,不如定长for循环和迭代for循环 1.通过forEach将数组中的元素逐个表示出来(遍历方法,读取操作). 2.通过map将原数组中的元素进行算数运算 ...

  7. js数组定义和方法 (包含ES5新增数组方法)

    数组Array 1. 数组定义 一系列数据的集合成为数组.数组的元素可以为任何类型的数据(包括数组,函数等),每个元素之间用逗号隔开,数组格式:[1,2,3]. 2. 数组创建方式 (1) 字面量方法 ...

  8. es5/6数组遍历以及常用的一些方法

    数组的遍历方法 1...for(var i=0;i<arr.length;i++){ } ---------------------------------------------------- ...

  9. ES5新增数组方法测试和字符串常见API测试

    首先是ES5新增数组方法测试: <!DOCTYPE html><html lang="en"><head> <meta charset=& ...

随机推荐

  1. thinkphp Trace方法

    页面Trace只能用于有页面输出的情况,但是trace方法可以用在任何情况,而且trace方法可以用于AJAX等操作. Trace方法的格式: trace('变量','标签','级别','是否记录日志 ...

  2. Objective-C 中的 Meta-class 是什么?

    在这篇文章中,我关注的是 Objective-C 中的一个陌生的概念-- meta-class.在 Objective-C 中的每个类都有一个相关联的 meta-class,但是你很少会直接使用 me ...

  3. http://www.2cto.com/ 红黑联盟

    http://www.2cto.com/ 红黑联盟,一个不错的学习或者开阔眼界的网站,内部由中文书写.比较适合国人.

  4. iOS开发之SceneKit框架--SCNScene.h

    1.SCNScene SCNScene是一个场景图——具有附加几何形状.光照.摄像机和其他属性的节点的层次结构,共同形成可显示的3D场景. 2.相关API简介 初始化方法 //懒加载 + (insta ...

  5. CentOS中GDB提示Missing separate debuginfos解决办法

    安装debuginfo 修改文件 vi /etc/yum.repo.d/CentOS-Debuginfo.repo 修改enabled的值为1 使用debuginfo-install安装需要的文件

  6. nginx实用配置用例

    vue项目部署及后台api访问 nginx.conf # vue本地项目配置 ... server { listen 8000; server_name localhost; root /.../di ...

  7. 机器学习-一对多(多分类)代码实现(matlab)

    %% Machine Learning Online Class - Exercise 3 | Part 1: One-vs-all % Instructions % ------------ % % ...

  8. C++开发系列-内联函数

    内联函数 C++使用内联函数来替代宏代码片段. #include <iostream> int main(){ printfA(); return 0; } inline void pri ...

  9. Expression表达式 实现and、or搜索

    用法: [HttpPost] public ActionResult GetBannerList(int pageIndex, int pageSize, string search) { Resul ...

  10. Python全栈开发:运算符

    1.算数运算: 2.比较运算: 3.赋值运算: 4.逻辑运算: 5.成员运算: