Js判斷兩個數(shù)組是否相等的幾種常見場景
前言
日常開發(fā),時不時會遇到需要判定2個數(shù)組是否相等的情況,需要實現(xiàn)考慮的場景有:
- 先判斷長度,長度不等必然不等
- 元素位置
- 其他情況考慮
'1'和1(Object的key是字符串, Map的key沒有限制)NaNnull和undefined
1、通過數(shù)組自帶方法比較
// 方式1
function isArrEqual1(arr1, arr2) {
if (arr1.length !== arr2.length) {
return false;
}
return arr1.every((v, i) => v === arr2[i]);
// return !arr1.some((v, i) => v !== arr2[i]);
// return arr1.filter((v, i) => v !== arr2[i]).length === 0;
// return arr1.findIndex((v, i) => v !== arr2[i]) === -1;
}
// 測試
const arr1 = [-2, "-1", 0, 0.1, 1, "2", "a", "", undefined, null],
arr2 = [-2, "-1", 0, 0.1, 1, "2", "a", "", undefined, null];
isArrEqual1(arr1, arr2); // true
數(shù)組自帶的方法,比較適合的有:every、some、filter、findIndex。
這種方式嚴格限制了數(shù)組元素長度、類型、位置必須一致。
注意包含NaN也無法比較!NaN是JS中唯一一個與自身不相等的存在!判斷NaN是否屬于同一個值得用Object.is(),如:Object.is(NaN, NaN); // true
2、通過循環(huán)判斷
// 方式2
function isArrEqual2(arr1, arr2) {
if (arr1.length !== arr2.length) {
return false;
}
for (let i = 0; i < arr1.length; i++) {
if (arr1[i] !== arr2[i]) {
return false;
}
}
return true;
}
這種判定方法限制及說明同上述方法1。
3、toString()
// 方式3
function isArrEqual3(arr1, arr2) {
if (arr1.length !== arr2.length) {
return false;
}
return arr1.toString() === arr2.toString();
}
// 測試
isArrEqual3(arr1, arr2); // true
const arr3 = ['', 1, null, undefined, {}, { a: 1 }, NaN, [], [2, 3], new Date()],
arr4 = ['', "1", undefined, null, {}, { a: 2 }, NaN, [], [2, "3"], new Date()];
isArrEqual3(arr3, arr4); // true
toString 方法是Object類型對象的實例方法,作用是返回一個對象的字符串形式。
這種方式限制了數(shù)組長度和元素位置,但是會發(fā)現(xiàn)有些元素類型沒有嚴格限制,這是由于js本身進行的數(shù)據(jù)隱式轉(zhuǎn)換!
在控制臺查看通過toString轉(zhuǎn)化后的數(shù)組,得到的結(jié)果如下:

此外,對數(shù)組、空數(shù)組、對象、空對象等引用類型,由于toString轉(zhuǎn)換結(jié)果都是[object Object],所以在比較的時候都會判定為相等!
還有,需要注意:
null == undefined // true null === undefined // false
4、join()
// 方式4
function isArrEqual4(arr1, arr2) {
if (arr1.length !== arr2.length) {
return false;
}
return arr1.join() === arr2.join();
}
join 方法是數(shù)組的一個實例方法,如果join這個方法如果不傳如分割符,其實作用幾乎和toString一樣,所以實現(xiàn)效果和限制同toString。

5、JSON.stringify()
// 方式5 [推薦]
function isArrEqual5(arr1, arr2) {
if (arr1.length !== arr2.length) {
return false;
}
return JSON.stringify(arr1) === JSON.stringify(arr2);
}
// 測試
isArrEqual5(arr1, arr2); // true
isArrEqual5(arr3, arr4); // false
const arr5 = [undefined, null, "", {}, { a: 1 }, NaN, [], [2, 3], new Date()],
arr6 = [undefined, null, "", {}, { a: 1 }, NaN, [], [2, 3], new Date()];
isArrEqual5(arr5, arr6); // true
JSON.stringify 用于將一個對象或值轉(zhuǎn)換成JSON字符串,轉(zhuǎn)換后結(jié)果會帶雙引號。

從測試結(jié)果可以看到,這個比較方式也嚴格的限制了數(shù)組長度、元素位置和元素類型,在日常中比較推薦此種方案~
總結(jié)
到此這篇關(guān)于Js判斷兩個數(shù)組是否相等的幾種常見場景的文章就介紹到這了,更多相關(guān)Js判斷兩個數(shù)組相等內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實現(xiàn)計算圓周率到小數(shù)點后100位的方法示例
這篇文章主要介紹了JavaScript實現(xiàn)計算圓周率到小數(shù)點后100位的方法,簡單分析了圓周率計算的原理并結(jié)合實例形式給出了javascript計算圓周率的具體操作技巧,需要的朋友可以參考下2018-05-05
起點頁面?zhèn)髦礿s,有空研究學(xué)習(xí)下
起點上的頁面?zhèn)髦礿s,有空研究下2010-01-01
bootstrap和jQuery.Gantt的css沖突 如何解決
這篇文章主要介紹了bootstrap和jQuery.Gantt的css沖突,本文給出了解決沖突的解決方法,感興趣的小伙伴們可以參考一下2016-05-05

