Js判斷兩個(gè)數(shù)組是否相等的幾種常見場景
前言
日常開發(fā),時(shí)不時(shí)會遇到需要判定2個(gè)數(shù)組是否相等的情況,需要實(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中唯一一個(gè)與自身不相等的存在!判斷NaN是否屬于同一個(gè)值得用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í)例方法,作用是返回一個(gè)對象的字符串形式。
這種方式限制了數(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]
,所以在比較的時(shí)候都會判定為相等!
還有,需要注意:
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ù)組的一個(gè)實(shí)例方法,如果join這個(gè)方法如果不傳如分割符,其實(shí)作用幾乎和toString一樣,所以實(shí)現(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
用于將一個(gè)對象或值轉(zhuǎn)換成JSON字符串,轉(zhuǎn)換后結(jié)果會帶雙引號。
從測試結(jié)果可以看到,這個(gè)比較方式也嚴(yán)格的限制了數(shù)組長度、元素位置和元素類型,在日常中比較推薦此種方案~
總結(jié)
到此這篇關(guān)于Js判斷兩個(gè)數(shù)組是否相等的幾種常見場景的文章就介紹到這了,更多相關(guān)Js判斷兩個(gè)數(shù)組相等內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實(shí)現(xiàn)計(jì)算圓周率到小數(shù)點(diǎn)后100位的方法示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)計(jì)算圓周率到小數(shù)點(diǎn)后100位的方法,簡單分析了圓周率計(jì)算的原理并結(jié)合實(shí)例形式給出了javascript計(jì)算圓周率的具體操作技巧,需要的朋友可以參考下2018-05-05起點(diǎn)頁面?zhèn)髦礿s,有空研究學(xué)習(xí)下
起點(diǎn)上的頁面?zhèn)髦礿s,有空研究下2010-01-01bootstrap和jQuery.Gantt的css沖突 如何解決
這篇文章主要介紹了bootstrap和jQuery.Gantt的css沖突,本文給出了解決沖突的解決方法,感興趣的小伙伴們可以參考一下2016-05-05