一、队尾插入pushjavascript
var colors = ["red","green"]; colors.push("black"): console.log(colors); //["red","green","black"]
二、队尾删除并返回删除的最后一项popjava
var colors = ["red","green","black"]; var item = colors.pop(); console.log(item); //"black"
三、队首插入unshift()数组
var colors = ["red","green"]; colors.unshift("black"); var item = colors.pop(); console.log(item); //"black"
四、队首删除shift()app
var colors = ["red","green","black"]; colors.shift(); console.log(colors); //["green","black"]
五、数组一添加数组二concat()函数
var colors = ["red","green","black"]; var colors2 = colors.concat("yellow",["blue","brown"]); console.log(colors); //["red","green","black"] console.log(colors2); //["red","green","black","yellow","blue","brown"]
六、数组的截取slice()
只传一个参数:从数组这个参数的下标开始截取一直到数组结束。code
var colors = ["red","green","black"]; colors.slice(1); //["green","black"] console.log(colors); //["red","green","black"]
传两个参数:第一个是截取开始的位置,第二个是截取结束的位置对象
var colors = ["red","green","black","yellow","blue","brown"]; colors.slice(1,3)//从位置1开始,到位置2结束["green","black"];
七、数组的splice()方法ip
有三种用法:
var colors = ["red","green","black"]; var removed = colors.splice(0,1); console.log(colors); //["green","black"] console.log(removed); //["red"] removed = colors.splice(1,0,"yellow","orange"); console.log(colors); //["green","yellow","orange","black"] console.log(removed); //[] removed = colors.splice(1,1,"red","purple"); console.log(colors); //["green","red","purple","orange","black"] console.log(removed); //["yellow"]
八、位置方法indexOf()和lastIndexOf()rem
indexOf()和lastIndexOf()都接收两个参数,第一个参数是要查找的项,第二个(可选)查找开始的位置,indexOf()是从数组头开始查,lastIndexOf()是从数组尾开始查找。
var numbers = [1,2,3,4,5,4,3,2,1]; console.log(numbers.indexOf(4)); //3 console.log(numbers.lastIndexOf(4)); //5 console.log(numbers.indexOf(4,4)); //5 var person = {name: "vivi"}; var people = [{name: "vivi"}]; var morePeople = [person]; console.log(people.indexOf(person)); //-1 console.log(morePeople.indexOf(person)); //0
九、查找find()方法
查找符合条件的第一项字符串
var inventory = [ {name: 'apples', quantity: 2}, {name: 'bananas', quantity: 0}, {name: 'cherries', quantity: 5} ]; const inventorItem = inventory.find((item) => item.name === 'apples'); console.log(inventorItem); //{name: 'apples', quantity: 2}
十、迭代方法
传入这些方法中的函数会接收三个参数:数组项的值、该项在数组中的位置和数组对象自己。
var numbers = [1,2,3,4,5,4,3,2,1]; var everyResult = numbers.every((item, index, array) => { return item > 2; }); console.log(everyResult); //false var someResult = numbers.some((item, index, array) => { return item > 2; }); console.log(someResult); //true
var numbers = [1,2,3,4,5,4,3,2,1]; var filterResult = numbers.filter((item, index, array) => { return item > 2; }); console.log(filterResult); //[3,4,5,4,3]
var numbers = [1,2,3,4,5,4,3,2,1]; var mapResult = numbers.map((item, index, array) => { return item * 2; }); console.log(mapResult); //[2,4,6,8,10,8,6,4,2]
var numbers = [1,2,3,4,5,4,3,2,1]; numbers.forEach((item, index, array) => { //执行某些操做 });
十一、归并方法reduce()和reduceRight()
这两个方法都会迭代数组的全部项,而后构建一个最终返回的值。 reduce()方法从数组的第一项开始,逐个遍历到最后。 reduceRight()则从数组的最后一项开始,向前遍历到第一项。
var values = [1,2,3,4,5]; var sum = values.reduce((prev, cur, index, array) => { return prev + cur; }); console.log(sum); //15
var values = [1,2,3,4,5]; var sum = values.reduceRight((prev, cur, index, array) => { return prev + cur; }); console.log(sum); //15