本文实例讲述了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
相关文章:
如何通过IIS搭建网站并配置访问权限?
如何用美橙互联一键搭建多站合一网站?
Java解压缩zip - 解压缩多个文件或文件夹实例
,网页ppt怎么弄成自己的ppt?
建站主机是否等同于虚拟主机?
ppt制作免费网站有哪些,ppt模板免费下载网站?
如何在阿里云部署织梦网站?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
免费ppt制作网站,有没有值得推荐的免费PPT网站?
成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
黑客如何利用漏洞与弱口令入侵网站服务器?
免费网站制作appp,免费制作app哪个平台好?
如何实现建站之星域名转发设置?
如何在香港服务器上快速搭建免备案网站?
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
如何做网站制作流程,*游戏网站怎么搭建?
建站之星收费标准详解:套餐费用及年费价格表一览
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
C#如何序列化对象为XML XmlSerializer用法
如何在腾讯云服务器上快速搭建个人网站?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
c# await 一个已经完成的Task会发生什么
如何配置WinSCP新建站点的密钥验证步骤?
如何在Windows环境下新建FTP站点并设置权限?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
如何在阿里云虚拟主机上快速搭建个人网站?
在线制作视频网站免费,都有哪些好的动漫网站?
如何快速搭建自助建站会员专属系统?
,怎么在广州志愿者网站注册?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
高防服务器租用如何选择配置与防御等级?
h5网站制作工具有哪些,h5页面制作工具有哪些?
建站三合一如何选?哪家性价比更高?
电商网站制作公司有哪些,1688网是什么意思?
大连网站制作公司哪家好一点,大连买房网站哪个好?
网站制作企业,网站的banner和导航栏是指什么?
如何撰写建站申请书?关键要点有哪些?
音响网站制作视频教程,隆霸音响官方网站?
重庆市网站制作公司,重庆招聘网站哪个好?
实例解析angularjs的filter过滤器
如何通过宝塔面板实现本地网站访问?
广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
详解jQuery停止动画——stop()方法的使用
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
c++ stringstream用法详解_c++字符串与数字转换利器
网站制作网站,深圳做网站哪家比较好?
*请认真填写需求信息,我们会在24小时内与您取得联系。