日常開發(fā),時不時會遇到需要判定2個數(shù)組是否相等的情況,需要實現(xiàn)考慮的場景有:
- 先判斷長度,長度不等必然不等
- 元素位置
- 其他情況考慮
-
'1'
和1
(Object的key是字符串, Map的key沒有限制) NaN
-
null
和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
。
這種方式嚴(yán)格限制了數(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)有些元素類型沒有嚴(yán)格限制,這是由于js本身進(jìn)行的數(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é)果會帶雙引號。文章來源:http://www.zghlxwxcb.cn/news/detail-836204.html
從測試結(jié)果可以看到,這個比較方式也嚴(yán)格的限制了數(shù)組長度、元素位置和元素類型,在日常中比較推薦此種方案~文章來源地址http://www.zghlxwxcb.cn/news/detail-836204.html
到了這里,關(guān)于Js如何判斷兩個數(shù)組是否相等?的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!