方法 | 描述 |
---|---|
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