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


相关推荐: 制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  韩国服务器如何优化跨境访问实现高效连接?  如何获取PHP WAP自助建站系统源码?  Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  Bootstrap CSS布局之列表  Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】  微信小程序 五星评分(包括半颗星评分)实例代码  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  如何在七牛云存储上搭建网站并设置自定义域名?  Laravel如何配置Horizon来管理队列?(安装和使用)  Swift中循环语句中的转移语句 break 和 continue  焦点电影公司作品,电影焦点结局是什么?  Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验  如何快速搭建自助建站会员专属系统?  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  动图在线制作网站有哪些,滑动动图图集怎么做?  html5的keygen标签为什么废弃_替代方案说明【解答】  php打包exe后无法访问网络共享_共享权限设置方法【教程】  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  如何用AI帮你把自己的生活经历写成一个有趣的故事?  如何快速上传建站程序避免常见错误?  Python函数文档自动校验_规范解析【教程】  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  网站制作大概多少钱一个,做一个平台网站大概多少钱?  Thinkphp 中 distinct 的用法解析  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  如何挑选最适合建站的高性能VPS主机?  如何在IIS7上新建站点并设置安全权限?  如何在Windows虚拟主机上快速搭建网站?  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  如何在香港服务器上快速搭建免备案网站?  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  什么是javascript作用域_全局和局部作用域有什么区别?  nginx修改上传文件大小限制的方法  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  Linux系统运维自动化项目教程_Ansible批量管理实战  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  微信小程序 配置文件详细介绍  Android自定义listview布局实现上拉加载下拉刷新功能  如何做网站制作流程,*游戏网站怎么搭建?