本篇文章為大家帶來了關於JavaScript中陣列的相關操作,主要包括Array物件原型方法以及常用操作去重、扁平化、排序等,希望對大家有幫助。
JavasScript陣列操作, 主要包含Array物件原型方法以及常用運算去重、扁平化、排序等
Array. prototype
forEach
#arr.forEach(callback(currentValue [, index [, array]])[, thisArg])
callback為數組中每個元素執行的函數, 此函數接收一至三個參數
currentValue數組中正在處理等目前元素的索引
array可選[表示正在操作的陣列]
thisArg可選[執行回呼函數時, 用作this的值, 當使用箭頭函數時此參數將被忽略]
forEach()對數組的每一個元素執行一次給定的函數
let arr = [1, 2, 3, 4, 5]; let obj = {a: 1}; arr.forEach(function(currentValue, index, array) { console.log("当前值:", currentValue);// 1 console.log("当前值索引:", index);// 0 console.log("当前处理数组:", array); // (5)[1, 2, 3, 4, 5] console.log("当前this指向:", this);// {a: 1} console.log("结束一次回调, 无需返回值"); console.log(""); }, obj); console.log(arr);// [1, 2, 3, 4, 5]不改变原数组
map
arr.map(callback(currentValue [, index [, array]])[, thisArg])
#callback為陣列每個元素執行的函數, 此函數接收一至三個參數
currentValue陣列中正在處理的目前元素
index可選[數組中正在處理的當前元素的索引]
array可選[正在操作的數組]
thisArg可選[當執行回調函數時, 用作this的值, 當使用箭頭函數時此函數將被忽略]
#map()創建一個新數組, 其結果是該數組中的每個元素都被呼叫一次提供的函數後的回傳值
let arr = [1, 2, 3, 4, 5]; let obj = {a: 1}; let newArr = arr.map(function(currentValue, index, array) { console.log("当前值:", currentValue);// 1 console.log("当前值索引:", index);// 0 console.log("当前处理数组:", array); // (5)[1, 2, 3, 4, 5] console.log("当前this指向: ", this); // {a: 1} console.log(""); return crrentValue + 10; }, obj); console.log(newArr);// [11, 12, 13, 14, 15] console.log(arr);// [1, 2, 3, 4, 5]不改变原数组
push
arr.push(element1[,. .., elementN])
elementN被加到數組末尾的元素
push()將一個或多個元素添加到數組的末尾, 並返回該數組的長度
let arr = ['a', 'b', 'c', 'd', 'e']; console.log(arr.push('f', 'g'));// 7 console.log(arr);// ["a", "b", "c", "d", "e", "f", "g"] 改变原数组
pop
pop()陣列中刪除最後一個元素, 並傳回該元素的值, 當陣列為空時傳回undefind, 此方法更改陣列的長度
let arr = [1, 2, 3, 4, 5]; console.log(arr.pop());// 5 console.log(arr);// [1, 2, 3, 4] 改变原数组
shift
#shift()從陣列中刪除第一個元素, 並傳回該元素的值, 該方法會改變原始陣列
let arr = [1, 2, 3, 4, 5] console.log(arr.shift());// 1 console.log(arr);// [2, 3, 4, 5] 改变原数组
unshift
#arr.unshift(element1[, ..., elementN])
unshift()將一個或多個元素加入到陣列的開頭, 並傳回該陣列的長度, 此方法修改原有陣列
let arr = [1, 2, 3, 4, 5] console.log(arr.unshift(-1, 0));// 7 console.log(arr);// [-1, 0, 1, 2, 3, 4, 5] 改变原数组
splice
##arrar.splice(start[, deleteCount[, item1[, item2[, ...]]]])
start指定修改的開始位置, 如果超出了陣列的長度, 則從數組末尾開始添加內容; 如果是負值, 則表示從數組末尾開始的第幾位(從-1計數, 這意味著-n是倒數第n個元素並且等價於array.length-1);若負數的絕對值大於陣列的長度, 則表示開始位置為第0位元
deleteCount可選[整數], 表示要移除的陣列元素的個數. 如果deleteCount大於start之後元素的總數, 則從statr後面的元素都將被刪除(含第start位). 如果deleteCount被省略, 或者它的值大於等於array.length-start(也就是說, 如果它大於或者等於start之後的所有元素的數量), 那麼start之後數組的所有元素都會被刪除
item1, item2, ...可選[要添加進數組的元素, 從start位置開始. 如果不指定, 則splice()將只刪除數組元素]
splice()透過刪除或替換現有元素或原地添加新的元素來修改數組, 並以數組形式返回被修改的內容, 此方法會改變原始數組
let arr = [1, 2, 3, 4, 5] console.log(arr.splice(1, 1));// [2] console.log(arr);// [1, 3, 4, 5] 改变原数组
slice
arr.slice([begin[, end]])
begin可選[提取起始處的索引] 從該索引開始提取原數組元素. 如果該參數為負數, 則表示從原數組中的倒數第幾個元素開始提取, 如果省略begin, 則slice從索引0開始; 如果begin大於原數組的長度, 則會傳回空數組
###end可選[提取終止處的索引], 在該索引處結束提取原數組元素. slice會提取原數組中索引從begin到end到所有元素, 包含begin, 但不包含end. 如果end 被省略, 則slice會一直提取到原始數組末尾, 如果end大於數組的長度, slice也會一直提取到數組末尾######slice()返回一個新的數組物件, 這個物件是由begin和end決定到原始數組的淺拷貝, 包括begin, 不包括end, 原始數組不會被改變###let arr = [1, 2, 3, 4, 5]; console.log(arr.sclice(1, 3));// [2, 3] console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
concat()用于合并两个或多个数组, 此方法不会更改现有数组, 而是返回一个新数组
let arr1 = [1, 2, 3]; let arr2 = [4, 5, 6]; let arr3 = arr1.concat(arr2); console.log(arr3);// [1, 2, 3, 4, 5, 6] console.log(arr1);// [1, 2, 3] 不改变原数组
join
arr.join([separator])
separator可选 指定一个字符串来分隔数组的每个元素
join()将一个数组(或一个类数组对象)的所有元素连接成一个字符串并返回这个字符串. 如果数组只有一个项目, 那么将返回该项目而不使用分隔符
let arr = ['a', 'b', 'c']; console.log(arr.join("&"));// a&b&c console.log(arr);// ["a", "b", "c"] 不改变数组
sort
arr.sort([compareFunction])
compareFunction可选 用来指定按某种顺序进行排列的函数. 如果省略, 元素按照转换为第字符串的各个字符的Unicode进行排序
firstEl第一个用于比较的元素
secondEl第二个用于比较的元素
sort()用原地算法对数组的元素进行排序, 并返回数组. 默认排序顺序是在将元素转换为字符串, 然后比较它们的UTF-16代码单元值序列时构建的
let arr = [1, 2, 3, 4, 5]; console.log(arr.sort((a, b) => b - a));// [5, 4, 3, 2, 1] console.log(arr);// [5, 4, 3, 2, 1] 改变原数组
reverse
reverse()将数组中元素的位置颠倒, 并返回该数组, 该方法会改变原数组
let arr = [1, 2, 3, 4, 5]; console.log(arr.reverse());// [5, 4, 3, 2, 1] console.log(arr);// [5, 4, 3, 2, 1] 改变原数组
every
every()测试一个数组内的所有元素是否都能通过某个指定函数的测试, 返回一个布尔值
let arr = [1, 2, 3, 4, 5]; console.log(arr.every(currentValue => currentValue > 1));// false console.log(arr);// 不改变原数组
some
some()测试数组中是不是至少有1个元素通过了提供的测试函数, 返回一个Boolean类型的值
let arr = [1, 2, 3 ,4 ,5]; console.log(arr.some(currentValue => currentValue > 1));// true console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
filter
filter()创建一个新数组, 其包含通过所提供的测试函数的所有元素
let arr = [1, 2, 3, 4, 5]; console.log(arr.filter(currentValue => currentValue > 2));// [3, 4, 5] console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
find
find()返回数组中满足提供的测试函数的第一个元素的值, 否则返回undefined
let arr = [1, 2, 3, 4, 5]; console.log(arr.find(currentValue => currentValue > 2));// 3 console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
findIndex
findIndex()返回数组中满足提供的测试函数的第一个元素的索引, 否则返回-1
let arr = [1, 2, 3, 4, 5]; console.log(arr.findIndex(currentValue => currentValue > 2));// 2 console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
includes
includes()用来判断一个数组是否包含一个指定的值, 如果包含则返回true, 否则返回false
let arr = [1, 2, 3, 4, 5]; console.log(arr.includes(2));// true console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
indexOf
indexof()返回指定元素在数组中的第一个索引, 否则返回-1
let arr = [1, 2, 3, 4, 5]; console.log(arr.indexOf(2));// 1 console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
lastIndexOf
lastIndexOf()返回指定元素在数组中的的最后一个索引, 如果不存在则返回-1
let arr = [1, 2, 3, 2, 1]; console.log(arr.lastIndexOf(2));// 3 console.log(arr);// [1, 2, 3, 2, 1] 不改变原数组
fill
fill()用一个固定值填充一个数组从起始索引到终止索引到全部元素, 不包括终止索引
let arr = [1, 2, 3, 4, 5]; console.log(arr.fill(0, 0, 5));// [0, 0, 0, 0, 0] console.log(arr);// [0, 0, 0, 0 ,0] 改变数组
flat
flat()会按照一个可指定的深度递归遍历数组, 并将所有元素与遍历到的子数组中的元素合并为一个新数组返回
let arr = [1, 2, [3, 4, [5]]]; console.log(arr.flat(2));// [1, 2, 3, 4, 5] console.log(arr);// [1, 2, [3, 4, [5]]] 不改变原数组
keys
keys()返回一个包含数组中每个索引键的Array Iterator对象
let arr = [1, 2, 3, 4, 5]; let iterator = arr.keys(); for (const key of iterator) { console.log(key); // 0 // 1 // 2 } console.log(arr);// [1, 2, 3, 4, 5] 不改变原数组
常用操作
数组去重
使用对象
let arr = [1, 2, 3, 1, 1, 1, 3, 5, 3]; let obj = {}; let newArr = []; arr.forEach(v => { if(!ogj[v]) { ogj[v] = 1; newArr.push(v); } }) console.log(newArr);// [1, 2, 3, 5]
使用Set
let arr = [1, 2, 3, 1, 1, 1, 3, 5, 3]; let newArr = Array.from(new Set(arr)); // let newArr = [...(new Set(arr))];// 使用ES6解构赋值 console.log(newArr);// [1, 2, 3, 5]
扁平化数组
使用flat
let arr = [1, 2, [3, 4, [5]]]; let newArr = arr.flat(2); console.log(newArr);// [1, 2, 3, 4, 5]
递归实现flat
function _flat(arr, maxN = 1, curN = 0) { let newArr = []; if (curN >= maxN) return arr; arr.forEach((v, i, array) => { if (Array.isArray(v)) { newArr.push(..._flat(v, maxN, curN + 1)); } else newArr.push(v); }) return newArr; } let arr = [1, 2, [3, 4, [5]]]; let newArr = _flat(arr, 1);// 扁平化一层 console.log(newArr);// [1, 2, 3, 4, [5]]
统计一个字符串中出现最多的字符
使用数组将字符的ASCII码作为key制作桶
let s = "ASASRKIADAA"; let arr = []; let base = 65;// A-Z 65-90 a-z 97-122 Array.prototype.forEach.call(s, (v) => { let ascii = v.charCodeAt(0) - base; if (arr[ascii]) { ++arr[ascii]; } else arr[ascii] = 1; }) let max = 0; let maxIndex = 0; arr.forEach((v, i) => { if (v > max) { max = v; maxIndex = i; } }) console.log(String.fromCharCode(maxIndex + base), arr[maxIndex]);// A 5
找出数组中的最大值
遍历数组
let arr = [1, 2, 3, 1, 1, 1, 3, 5, 3]; let max = -Infinity; arr.forEach(v => { if (v > max) max = v; }) console.log(max);// 5
使用Math
let arr = [1, 2, 3, 1, 1, 1, 3, 5, 3]; let max = Math.max(...arr); console.log(max);// 5
使用reduce
let arr = [1, 2, 3, 1, 1, 1, 3, 5, 3]; let max = arr.reduce((a, v) => { return a > v ? a : v; }) console.log(max);// 5
拷贝数组
遍历数组使用push
let arr = [1, 2, 3, 4, 5]; let newArr = []; arr.forEach(v => newArr.push(v)); console.log(newArr);// [1, 2, 3, 4, 5]
使用concat
let arr = [1, 2, 3, 4, 5]; let newArr = [].concat(arr); console.log(newArr);// [1, 2, 3, 4, 5]
使用slice
let arr = [1, 2, 3, 4, 5]; let newArr = arr.slice(0); console.log(newArr);// [1, 2, 3, 4, 5];
随机打乱一个数组
随机交换N次
function randomInt(a, b) { return Number.parseInt(Math.random() * (b-a) + a); } let arr = [1, 2, 3, 4, 5]; let N = arr.length; arr.forEach((v, i, arr) => { let ran = randomInt(0, N); [arr[i], arr[ran]] = [arr[ran], arr[i]]; }) console.log(arr);
随机排序
let arr = [1, 2, 3, 4, 5]; arr.sort((v1, v2) => { return Math.random() >= 0.5 ? 1 : -1; }) console.log(arr);
【相关推荐:javascript学习教程】
以上是經典技巧之JavaScript陣列操作(整理分享)的詳細內容。更多資訊請關注PHP中文網其他相關文章!