全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

本文实例讲述了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 


相关文章: 如何在阿里云完成域名注册与建站?  建站之星安装模板失败:服务器环境不兼容?  山东云建站价格为何差异显著?  宝塔建站无法访问?如何排查配置与端口问题?  建站之星3.0如何解决常见操作问题?  如何用美橙互联一键搭建多站合一网站?  如何确保西部建站助手FTP传输的安全性?  ,怎么用自己头像做动态表情包?  孙琪峥织梦建站教程如何优化数据库安全?  如何快速搭建高效简练网站?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  建站之星后台管理如何实现高效配置?  IOS倒计时设置UIButton标题title的抖动问题  小建面朝正北,A点实际方位是否存在偏差?  如何用PHP快速搭建高效网站?分步指南  如何在建站宝盒中设置产品搜索功能?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  如何在Windows虚拟主机上快速搭建网站?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  建站之星免费版是否永久可用?  专业商城网站制作公司有哪些,pi商城官网是哪个?  网站制作说明怎么写,简述网页设计的流程并说明原因?  如何将凡科建站内容保存为本地文件?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  如何在宝塔面板中创建新站点?  活动邀请函制作网站有哪些,活动邀请函文案?  如何选择美橙互联多站合一建站方案?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  ,网页ppt怎么弄成自己的ppt?  如何在建站之星网店版论坛获取技术支持?  名字制作网站免费,所有小说网站的名字?  建站主机选购指南:核心配置与性价比推荐解析  如何通过FTP服务器快速搭建网站?  潮流网站制作头像软件下载,适合母子的网名有哪些?  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  高防服务器租用首荐平台,企业级优惠套餐快速部署  做企业网站制作流程,企业网站制作基本流程有哪些?  如何在腾讯云免费申请建站?  如何快速配置高效服务器建站软件?  如何快速查询域名建站关键信息?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  寿县云建站:智能SEO优化与多行业模板快速上线指南  如何通过VPS建站无需域名直接访问?  网站制作难吗安全吗,做一个网站需要多久时间?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  如何在Tomcat中配置并部署网站项目? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。