js数组的方法集合

方法 描述
toString() 吧数组转换为字符串并返回结果
join() 把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔。
concat() 连接两个或更多的数组,并返回结果。
pop() 删除并返回数组的最后一个元素
push() 向数组末尾添加一个或更多元素,并返回新的长度
shift() 删除并返回数组的第一个元素
unshift() 像数组的开头添加一个或更多元素,并返回新的长度
slice() 从某个已有的数组返回指定的元素
splice() 删除元素, 并向数组添加新元素
reverse() 颠倒数组中的元素的顺序
sort() 对数组的元素进行排序
valueOf() 返回数组对象的原始值
------------- ------------------
arr.forEach(callback) 遍历,循环 ( 对于空数组不会执行回调函数) 无return 即使有return,也不会返回任何值,并且会影响原来的数组
arr.map(callback) 映射数组(遍历数组),有return 返回一个新数组
arr.filter(callback) 过滤数组,返回一个满足要求的数组
arr.every(callback) 依据判断条件,数组的元素是否全满足,若满足则返回true
arr.some() 数组的元素是否有一个满足,若有一个满足则返回true
arr.reduce(callback, initialValue) 迭代数组的所有项,累加器,数组中的每个值(从左到右)合并,最终计算为一个值
Array.from() 将伪数组变成数组,就是只要有length的就可以转成数组。 ---es6
Array.of() 将一组值转换成数组,类似于声明数组 ---es6
arr.find(callback) 找到第一个符合条件的数组成员
arr.findIndex(callback) 找到第一个符合条件的数组成员的索引值
arr.includes() 判断数中是否包含给定的值
arr.keys() 遍历数组的键名
arr.values() 遍历数组键值
arr.entries() 遍历数组的键名和键值

1. toString()

JavaScript 方法 toString() 把数组转换为数组值(逗号分隔)的字符串。

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.toString();  // "Banana,Orange,Apple,Mango"

2. join()

将所有数组元素结合为一个字符串。
可以规定分隔符

var fruits = ["Banana", "Orange","Apple", "Mango"];
fruits.join(" --- ");   // "Banana --- Orange --- Apple --- Mango"

3. concat()

合并数组

var arr1 = ["Cecilie", "Lone"];
var arr2 = ["Emil", "Tobias", "Linus"];
var myChildren = arr1.concat(arr2,  ["Robin", "Morgan"]);   // ["Cecilie", "Lone", "Emil", "Tobias", "Linus", "Robin", "Morgan"]

4. pop()

从数组中删除最后一个元素:(改变原数组)

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.pop();  // "Mango"
fruits  // ["Banana", "Orange", "Apple"]

5. push()

在数组结尾处 向数组添加一个新的元素:(改变原数组)

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.push("Kiwi");   // 5 新数组的length
fruits  // ["Banana", "Orange", "Apple", "Mango", "Kiwi"]

6. shift()

删除数组首个元素

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.shift();  // "Banana"
fruits  // ["Orange", "Apple", "Mango"]

7. unshift()

向数组开头添加新元素

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.unshift("Lemon");    // 向 fruits 添加新元素 "Lemon"
fruits  // ["Lemon", "Banana", "Orange", "Apple", "Mango"]

8. slice()

用数组的某个片段切出新数组。(原数组不变)

var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(1, 3); 

9. splice()

向数组添加新项:

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2, 1, "Lemon", "Kiwi");  // ["Apple"]
fruits // ["Banana", "Orange", "Lemon", "Kiwi", "Mango"]

第一个参数(2)定义了应添加新元素的位置(拼接)。
第二个参数(0)定义应删除多少元素。
其余参数(“Lemon”,“Kiwi”)定义要添加的新元素。
splice() 方法返回一个包含已删除项的数组:


var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(0, 1);   // ["Banana"]
fruits  // ["Orange", "Apple", "Mango"]
第一个参数(0)定义新元素应该被添加(接入)的位置。
第二个参数(1)定义应该删除多个元素。
其余参数被省略。没有新元素将被添加。

10. reverse()

11. reduce

迭代数组的所有项,累加器,数组中的每个值(从左到右)合并,最终计算为一个值

let arr = [{done: true,name: '11'},{done: true,name: '22'},{done: false,name: '33'},{done: true,name: '44'}]
var sum = arr.reduce((it) => {return it.done})
var sum = arr.reduce((pre, current) => {return pre+(current.done ? 1 : 0)}, 0)

sum  // 3

delete 运算符

delete 删除之后位置还在内容是undefined,length 不变
var fruits = ["Banana", "Orange", "Apple", "Mango"];
delete fruits[0]; // 把 fruits 中的首个元素改为 undefined

数组的方法面试很容易被问到. reduce sort

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 遍历数组 处理数组的方法 循环效率性能排行:for > for-of(ES6新增) > forEach > fil...
    web偶然事件阅读 515评论 1 7
  • 1 arr.push() 从后面添加元素,返回值为添加完后的数组的长度 2 arr.pop() 从后面删除元素,只...
    每天进步一点点5454阅读 256评论 0 0
  • 1 arr.push() 从后面添加元素,返回值为添加完后的数组的长度 2 arr.pop() 从后面删除元素,只...
    LIXIAOJUN7阅读 385评论 3 2
  • 数组方法 最近总结了一些数组的方法,希望能给大家带来一些帮助吧 1.Array.isArray()方法用来判断一个...
    G_zefeng阅读 660评论 0 11
  • 1.数组的去重 方式一 方式二 方式三 方式四 数组中含有对象时的去重var arr = [{ a: 1, b: ...
    learninginto阅读 782评论 0 10