JavaScript中比较两个对象是否相等的方法

不言
Lepaskan: 2019-02-25 10:29:53
ke hadapan
2970 orang telah melayarinya

本篇文章给大家带来的内容是关于JavaScript中比较两个对象是否相等的方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

这是我在一次面试中,被面试官所提问的一道题

在这次面试题中

相等:指的是对象的属性个数值相等

有这样两个obj

let obj1 = {
    name:'李德华',
    age:18,
    price:NaN
}

let obj2 = {
    name:'张德华',
    age:18,
    price:NaN
}
Salin selepas log masuk

我能想到的一种方案

function compare(obj1,obj2){
    if(Object.keys(obj1).length != Object.keys(obj2).length){
      return false
    }else{
      for(key in obj1){
        if(obj2.hasOwnProperty(key)){
            if( !Object.is(obj1[key],obj2[key])){
                return false;
            }
        }else{
          return false
        }
      }
      return true
    }
}
Salin selepas log masuk

解答过程的思考

  • 由于obj没有length,我只能通过Object.keys()转化成数组

  • 进入第二步,对象中的属性在另一个obj中是否存在。此处使用了Object.hasOwnProperty() 仅对该对象中的属性进行对比(避免obj继承了父级的属性)

  • 承载第二步的基础对属性值进行比对。ES6中Object.is()来避免出现NaN不等于自身的问题

或者使用 Underscore.js中的_.isEqual

Atas ialah kandungan terperinci JavaScript中比较两个对象是否相等的方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:segmentfault.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan