前端小功能:數組對象是否相等


前端小功能:數組對象是否相等,是否一致。
JS 判斷兩個數組是否相同

JSON.stringify([1,2,3].sort()) === JSON.stringify([3,2,1].sort()); //true

 JS 判斷兩個數組對象是否相等

花了一天的時間,去實現兩個對象是否相等的情況,具體代碼如下:

export function isEqual(a, b) {
  let Equal = true
  if((typeof a) === 'object' && (typeof b) === 'object'){
    let aProps = Object.getOwnPropertyNames(a);
    let bProps = Object.getOwnPropertyNames(b);
    if (aProps.length !== bProps.length) {
        Equal = false;
        return Equal
    }
    // eslint-disable-next-line @typescript-eslint/prefer-for-of
    for (let i = 0; i < aProps.length; i++) {
      let propName = aProps[i]
      let propA = a[propName]
      let propB = b[propName]
      if((typeof propA) === 'object' && (typeof propB) === 'object'){
        if(!isEqual(propA, propB)){
          Equal = false;
          return Equal
        }
      }else if(propA !== propB){
        Equal = false
        return Equal
      }
    }
  }else if(a !== b){
    Equal = false
    return Equal
  }
  return Equal
}

 

然后花了一個小時,去查一下其他的庫。

開箱即用:https://www.lodashjs.com/docs/lodash.isEqual

執行深比較來確定兩者的值是否相等。

**注意: **這個方法支持比較 arrays, array buffers, booleans, date objects, error objects, maps, numbers, Object objects, regexes, sets, strings, symbols, 以及 typed arrays. Object 對象值比較自身的屬性,不包括繼承的和可枚舉的屬性。 不支持函數和DOM節點比較。


發現lodash非常的好。建議前端必須掌握,減少50%數據處理的時間,如果自己想了解原理的話,自己擼一波還是很好的。

lodash 中文文檔: https://www.lodashjs.com/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM