JS判断两个对象内容是否相等的方法示例

发布时间 - 2026-01-11 00:35:14    点击率:

本文实例讲述了JS判断两个对象内容是否相等的方法。分享给大家供大家参考,具体如下:

我们知道,如果两个对象即使内容,JavaScript也会判断它们不相等。但是有时候,我们仅仅需要判断两个对象的内容是否相等。那么我们应该如何做到且考虑周全呢?比如说0和-0,null和undefined,是不相等的,NaN和NaN默认是不相等的。我写了一个isEqual方法,考虑到了诸多方面,代码如下:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <body>
  </body>
<script type="text/javascript">
//isEqual:判断两个对象是否键值对应相等
function isEqual(a,b){
  //如果a和b本来就全等
  if(a===b){
    //判断是否为0和-0
    return a !== 0 || 1/a ===1/b;
  }
  //判断是否为null和undefined
  if(a==null||b==null){
    return a===b;
  }
  //接下来判断a和b的数据类型
  var classNameA=toString.call(a),
    classNameB=toString.call(b);
  //如果数据类型不相等,则返回false
  if(classNameA !== classNameB){
    return false;
  }
  //如果数据类型相等,再根据不同数据类型分别判断
  switch(classNameA){
    case '[object RegExp]':
    case '[object String]':
    //进行字符串转换比较
    return '' + a ==='' + b;
    case '[object Number]':
    //进行数字转换比较,判断是否为NaN
    if(+a !== +a){
      return +b !== +b;
    }
    //判断是否为0或-0
    return +a === 0?1/ +a === 1/b : +a === +b;
    case '[object Date]':
    case '[object Boolean]':
    return +a === +b;
  }
  //如果是对象类型
  if(classNameA == '[object Object]'){
    //获取a和b的属性长度
    var propsA = Object.getOwnPropertyNames(a),
      propsB = Object.getOwnPropertyNames(b);
    if(propsA.length != propsB.length){
      return false;
    }
    for(var i=0;i<propsA.length;i++){
      var propName=propsA[i];
      //如果对应属性对应值不相等,则返回false
      if(a[propName] !== b[propName]){
        return false;
      }
    }
    return true;
  }
  //如果是数组类型
  if(classNameA == '[object Array]'){
    if(a.toString() == b.toString()){
      return true;
    }
    return false;
  }
}
//test
var obj1={name:"liu",age:22};
var obj2={name:"liu",age:22};
var obj3={name:"liu",age:33};
var state1=isEqual(obj1,obj2);
var state2=isEqual(obj1,obj3);
console.log(state1);//true
console.log(state2);//false
var state3=isEqual(null,undefined);
console.log(state3);//false
var state4=isEqual(NaN,NaN);
console.log(state4);//true
var arr1=[1,2,3];
var arr2=[1,2,3];
var arr3=[1,23];
var state5=isEqual(arr1,arr2);
console.log(state5);//true
var state6=isEqual(arr1,arr3);
console.log(state6);//false
</script>
</html>

运行效果图如下:

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript中json操作技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。


# JS  # 判断  # 对象  # 相等  # AngularJS模糊查询功能实现代码(过滤内容下拉菜单排序过滤敏感字符验证判断后添加表格信息)  # JavaScript判断数组重复内容的两种方法(推荐)  # javascript简单判断输入内容是否合法的方法  # JavaScript判断DIV内容是否为空的方法  # js判断文本框输入的内容是否为数字  # JS判断文本框内容改变事件的简单实例  # js实现数组去重、判断数组以及对象中的内容是否相同  # 基于JavaScript判断两个对象内容是否相等  # 不相等  # 判断是否  # 也会  # 相关内容  # 遍历  # 数据结构  # 给大家  # 写了  # 我们应该  # 更多关于  # 所述  # 程序设计  # 键值  # 面向对象  # 操作技巧  # 全等  # 讲述了  # 本来就  # utf  # charset 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在不使用负向后查找的情况下匹配特定条件前的换行符  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  如何在腾讯云服务器快速搭建个人网站?  简历没回改:利用AI润色让你的文字更专业  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  Android自定义控件实现温度旋转按钮效果  Laravel如何与Pusher实现实时通信?(WebSocket示例)  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  在线教育网站制作平台,山西立德教育官网?  西安专业网站制作公司有哪些,陕西省建行官方网站?  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  如何为不同团队 ID 动态生成多个独立按钮  浅谈Javascript中的Label语句  北京网站制作的公司有哪些,北京白云观官方网站?  Win11怎么设置默认图片查看器_Windows11照片应用关联设置  如何在IIS中配置站点IP、端口及主机头?  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  高防服务器租用首荐平台,企业级优惠套餐快速部署  长沙做网站要多少钱,长沙国安网络怎么样?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  使用C语言编写圣诞表白程序  Laravel中间件如何使用_Laravel自定义中间件实现权限控制  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  Android滚轮选择时间控件使用详解  海南网站制作公司有哪些,海口网是哪家的?  音乐网站服务器如何优化API响应速度?  进行网站优化必须要坚持的四大原则  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  Laravel如何发送系统通知?(Notification渠道示例)  Linux系统运维自动化项目教程_Ansible批量管理实战  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  详解Android中Activity的四大启动模式实验简述  中山网站制作网页,中山新生登记系统登记流程?  浅谈javascript alert和confirm的美化  Laravel如何生成URL和重定向?(路由助手函数)  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?