JS判斷兩個(gè)對(duì)象內(nèi)容是否相等

ES6有一個(gè)方法來(lái)判斷兩個(gè)對(duì)象是否相等

console.log(Object.is(a,b))

但是這個(gè)相等眶诈,和我們平時(shí)要的相等可能不一樣
這個(gè)方法判斷的是a和b是不是同一個(gè)指針的對(duì)象

比如說(shuō)

var a = {
  id:1
};
var b = a;
console.log(Object.is(a,b));   //true

但是下面這種情況就不管用了

var a = {
  id:1
};
var b = {
  id:1
}
console.log(Object.is(a,b));   //false

當(dāng)我們只需要兩個(gè)對(duì)象的內(nèi)容相同的時(shí)候,他就沒(méi)效果了

思路
只要兩個(gè)對(duì)象的名和鍵值都相同品腹。那么兩個(gè)對(duì)象的內(nèi)容就相同了

1.用Object.getOwnPropertyNames拿到對(duì)象的所以鍵名數(shù)組
2.比對(duì)鍵名數(shù)組的長(zhǎng)度是否相等胶逢。否=>false饭聚。真=>3
3.比對(duì)鍵名對(duì)應(yīng)的鍵值是否相等

    function isObjectValueEqual(a, b) {
        var aProps = Object.getOwnPropertyNames(a);
        var bProps = Object.getOwnPropertyNames(b);

        if (aProps.length != bProps.length) {
            return false;
        }

        for (var i = 0; i < aProps.length; i++) {
            var propName = aProps[i];
            var propA = a[propName];
            var propB = b[propName];
            if ( propA !== propB) {
                    return false;
            }
        }
        return true;
    }

粗略一看沒(méi)問(wèn)題
但是細(xì)心的同學(xué)發(fā)現(xiàn)如果 鍵值也是對(duì)象的話
那這個(gè)方法就不管用了

    var a = {
        id:1,
        name:2,
        c:{
            age:3
        }
    };
    var b = {
        id:1,
        name:2,
        c:{
            age:3
        }
    }
    console.log(isObjectValueEqual(a,b));//false

這個(gè)時(shí)候遞歸一下就可以解決了
注意蛔溃,遞歸的時(shí)候要判斷prop是不是Object肌毅,然后會(huì)進(jìn)入無(wú)限遞歸的死循環(huán)

function isObjectValueEqual(a, b) {
     var aProps = Object.getOwnPropertyNames(a);
     var bProps = Object.getOwnPropertyNames(b);
      if (aProps.length != bProps.length) {
           return false;
      }
      for (var i = 0; i < aProps.length; i++) {
        var propName = aProps[i]

        var propA = a[propName]
        var propB = b[propName]
       // 2020-11-18更新砌烁,這里忽略了值為undefined的情況
      // 故先判斷兩邊都有相同鍵名
       if(!b.hasOwnProperty(propName)) return false
        if ((propA instanceof Object)) {
          if (this.isObjectValueEqual(propA, propB)) {
              // return true     這里不能return ,后面的對(duì)象還沒(méi)判斷
            } else {
              return false
            }
        } else if (propA !== propB) {
          return false
        } else { }
      }
    return true
    }
    var a = {
        id:1,
        name:2,
        c:{
            age:3
        }
    };
    var b = {
        id:1,
        name:2,
        c:{
            age:3
        }
    }
    console.log(isObjectValueEqual(a,b));//true
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末筐喳,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子函喉,更是在濱河造成了極大的恐慌疏唾,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,640評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件函似,死亡現(xiàn)場(chǎng)離奇詭異槐脏,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)撇寞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門顿天,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蔑担,你說(shuō)我怎么就攤上這事牌废。” “怎么了啤握?”我有些...
    開(kāi)封第一講書人閱讀 165,011評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵鸟缕,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng)懂从,這世上最難降的妖魔是什么授段? 我笑而不...
    開(kāi)封第一講書人閱讀 58,755評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮番甩,結(jié)果婚禮上侵贵,老公的妹妹穿的比我還像新娘。我一直安慰自己缘薛,他們只是感情好窍育,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,774評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著宴胧,像睡著了一般漱抓。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上恕齐,一...
    開(kāi)封第一講書人閱讀 51,610評(píng)論 1 305
  • 那天乞娄,我揣著相機(jī)與錄音,去河邊找鬼檐迟。 笑死补胚,一個(gè)胖子當(dāng)著我的面吹牛码耐,可吹牛的內(nèi)容都是我干的追迟。 我是一名探鬼主播,決...
    沈念sama閱讀 40,352評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼骚腥,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼敦间!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起束铭,我...
    開(kāi)封第一講書人閱讀 39,257評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤廓块,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后契沫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體带猴,經(jīng)...
    沈念sama閱讀 45,717評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,894評(píng)論 3 336
  • 正文 我和宋清朗相戀三年懈万,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了拴清。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,021評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡会通,死狀恐怖口予,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情涕侈,我是刑警寧澤沪停,帶...
    沈念sama閱讀 35,735評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響木张,放射性物質(zhì)發(fā)生泄漏众辨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,354評(píng)論 3 330
  • 文/蒙蒙 一窟哺、第九天 我趴在偏房一處隱蔽的房頂上張望泻轰。 院中可真熱鬧,春花似錦且轨、人聲如沸浮声。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,936評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)泳挥。三九已至,卻和暖如春至朗,著一層夾襖步出監(jiān)牢的瞬間屉符,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,054評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工锹引, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留矗钟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,224評(píng)論 3 371
  • 正文 我出身青樓嫌变,卻偏偏與公主長(zhǎng)得像吨艇,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子腾啥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,974評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 第2章 基本語(yǔ)法 2.1 概述 基本句法和變量 語(yǔ)句 JavaScript程序的執(zhí)行單位為行(line)东涡,也就是一...
    悟名先生閱讀 4,149評(píng)論 0 13
  • 屬性的簡(jiǎn)潔表示法 ES6允許直接寫入變量和函數(shù),作為對(duì)象的屬性和方法倘待。 上面代碼表明疮跑,ES6允許在對(duì)象之中,直接寫...
    oWSQo閱讀 509評(píng)論 0 0
  • 一凸舵、數(shù)組定義 array() 1祖娘、索引數(shù)組 在一個(gè)變量中,存儲(chǔ)一個(gè)或多個(gè)值啊奄。數(shù)組中的每一個(gè)元素都有一個(gè)訪問(wèn)ID渐苏,根...
    竹與豆閱讀 530評(píng)論 0 0
  • 1 Object 對(duì)象 教程:https://wangdoc.com/javascript/stdlib/obje...
    智勇雙全的小六閱讀 1,760評(píng)論 0 0
  • 西子湖畔是一個(gè)魂繞的夢(mèng)…… 從王子健的一首西湖蝶戀;高勝美的一首《千年等一回》增热;許嵩的《斷橋殘雪》等…… 無(wú)論是現(xiàn)...
    獨(dú)憐幽竹閱讀 432評(píng)論 0 3