JS中操作数组的方法(涵盖ES6) |
您所在的位置:网站首页 › js将数组转化为对象 › JS中操作数组的方法(涵盖ES6) |
一、常用的 JavaScript 操作数组的方法 1.push() 和 pop():在数组末尾添加或删除元素。 let arr = [1, 2, 3]; arr.push(4); // [1, 2, 3, 4] arr.pop(); // [1, 2, 3]2.shift() 和 unshift():在数组头部删除或添加元素。 let arr = [1, 2, 3]; arr.unshift(0); // [0, 1, 2, 3] arr.shift(); // [1, 2, 3]3.splice():在任意位置添加或删除元素。如果删除一个元素,则返回一个元素的数组。 如果未删除任何元素,则返回空数组。(改变原始数组) let arr = [1, 2, 3]; arr.splice(1, 1, 4); // [1, 4, 3]4.slice():截取数组的一部分 let arr = [1, 2, 3]; let subArr = arr.slice(0, 2); // [1, 2]5.concat():串联多个数组。 let arr1 = [1, 2]; let arr2 = [3, 4]; let arr3 = arr1.concat(arr2); // [1, 2, 3, 4]6.filter():根据条件过滤数组。 let arr = [1, 2, 3, 4, 5]; let evenArr = arr.filter((num) => num % 2 === 0); // [2, 4]7.map():根据条件映射数组(返回一个新数组)。 let arr = [1, 2, 3]; let doubleArr = arr.map((num) => num * 2); // [2, 4, 6]8.reduce():将数组缩减为单个值(数组求和)。 let arr = [1, 2, 3]; let sum = arr.reduce((acc, num) => acc + num, 0); // 69.find():返回满足条件的第一个数组元素。 let arr = [1, 2, 3]; let firstEven = arr.find((num) => num % 2 === 0); // 210.findIndex():返回满足条件的第一个数组元素的索引。 let arr = [1, 2, 3]; let firstEvenIndex = arr.findIndex((num) => num % 2 === 0); // 111.some() 和 every():判断数组中是否有满足指定条件的元素。 let arr = [1, 2, 3]; let hasEven = arr.some((num) => num % 2 === 0); // true let allEven = arr.every((num) => num % 2 === 0); // false12.includes():检查数组中是否包含特定元素(用于引用对象)。 let arr = [1, 2, 3]; let includes2 = arr.includes(2); // true let includes4 = arr.includes(4); // false13.flat():将嵌套数组拍平为一维数组。 let arr = [1, 2, [3, 4]]; let flatArr = arr.flat(); // [1, 2, 3, 4]14.fill():用指定值填充数组。 let arr = new Array(3).fill(0); // [0, 0, 0]15.sort():按照某个规则排序数组。 let arr = [3, 2, 1]; arr.sort(); // [1, 2, 3] var points = [40,100,1,5,25,10]; points.sort(function(a,b){return a-b}); // 1,5,10,25,40,100 var points = [40,100,1,5,25,10]; points.sort(function(a,b){return b-a}); // 100,40,25,10,5,116.entries()、keys() 和 values():遍历数组并返回一个迭代器对象,分别包括数组的键、键名和值。 let arr = ["a", "b", "c"]; for (let [index, item] of arr.entries()) { console.log(index, item); // 0 'a' 1 'b' 2 'c' }17. from():将类数组对象或可迭代对象转化为数组。 let str = "abc"; let arr = Array.from(str); // ['a', 'b', 'c']18.Array.of():创建由任意数量参数组成的数组。 let arr = Array.of(1, 2, 3); // [1, 2, 3]19.copyWithin():在数组内部进行元素替换。 let arr = [1, 2, 3, 4]; arr.copyWithin(1, 2, 3); // [1,3,3,4] 复制数组的前面两个元素到第三和第四个位置上: var fruits = ["Banana", "Orange", "Apple", "Mango", "Kiwi", "Papaya"]; fruits.copyWithin(2, 0, 2); //Banana,Orange,Banana,Orange,Kiwi,Papaya 复制数组的前面两个元素到后面两个元素上: var fruits = ["Banana", "Orange", "Apple", "Mango"]; fruits.copyWithin(2, 0); //Banana,Orange,Banana,Orange20.Symbol.species:可以通过 Symbol.species 改变数组方法的返回类型。 class MyArray extends Array { static get [Symbol.species]() { return Array; } } let arr = new MyArray(1, 2, 3); let newArr = arr.map((num) => num * 2); console.log(newArr instanceof MyArray); // false console.log(newArr instanceof Array); // true21.reduceRight():类似于 reduce(),但是从右到左迭代。 let arr = [1, 2, 3]; let sum = arr.reduceRight((acc, num) => acc + num, 0); // 622.flatMap():类似于 map(),但是可以将嵌套的数组拍平后再进行映射。 let arr = ["hello world", "i am learning javascript"]; let words = arr.flatMap((str) => str.split(" ")); // ["hello", "world", "i", "am", "learning", "javascript"]23.everyNth():返回数组中每个第 n 个元素。 let arr = [1, 2, 3, 4, 5]; function everyNth(arr, nth) { return arr.filter((val, index) => index % nth === nth - 1); } let result = everyNth(arr, 2); // [2, 4]24.zip():将多个数组转化为一个数组,其中第 i 个元素包括所有数组的第 i 个元素。 function zip(...arrays) { return [...arrays].reduce((acc, arr) => { return arr.map((val, i) => (acc[i] || []).concat(val)); }, []); } let arr1 = [1, 2, 3]; let arr2 = ["a", "b", "c"]; let arr3 = [true, false, true]; let zipped = zip(arr1, arr2, arr3); // [[1, 'a', true], [2, 'b', false], [3, 'c', true]] |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |