欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS判斷兩個對象內(nèi)容是否相等的方法示例

 更新時間:2017年04月10日 10:56:33   作者:布瑞澤的童話  
這篇文章主要介紹了JS判斷兩個對象內(nèi)容是否相等的方法,結(jié)合具體實例形式分析了javascript針對字符串、數(shù)組及對象的相關(guān)判斷技巧,需要的朋友可以參考下

本文實例講述了JS判斷兩個對象內(nèi)容是否相等的方法。分享給大家供大家參考,具體如下:

我們知道,如果兩個對象即使內(nèi)容,JavaScript也會判斷它們不相等。但是有時候,我們僅僅需要判斷兩個對象的內(nèi)容是否相等。那么我們應(yīng)該如何做到且考慮周全呢?比如說0和-0,null和undefined,是不相等的,NaN和NaN默認(rèn)是不相等的。我寫了一個isEqual方法,考慮到了諸多方面,代碼如下:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <body>
  </body>
<script type="text/javascript">
//isEqual:判斷兩個對象是否鍵值對應(yīng)相等
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的數(shù)據(jù)類型
  var classNameA=toString.call(a),
    classNameB=toString.call(b);
  //如果數(shù)據(jù)類型不相等,則返回false
  if(classNameA !== classNameB){
    return false;
  }
  //如果數(shù)據(jù)類型相等,再根據(jù)不同數(shù)據(jù)類型分別判斷
  switch(classNameA){
    case '[object RegExp]':
    case '[object String]':
    //進(jìn)行字符串轉(zhuǎn)換比較
    return '' + a ==='' + b;
    case '[object Number]':
    //進(jìn)行數(shù)字轉(zhuǎn)換比較,判斷是否為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];
      //如果對應(yīng)屬性對應(yīng)值不相等,則返回false
      if(a[propName] !== b[propName]){
        return false;
      }
    }
    return true;
  }
  //如果是數(shù)組類型
  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>

運行效果圖如下:

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript中json操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

  • RxJS的入門指引和初步應(yīng)用

    RxJS的入門指引和初步應(yīng)用

    這篇文章主要介紹了RxJS的入門指引和初步應(yīng)用,RxJS是一個強(qiáng)大的Reactive編程庫,提供了強(qiáng)大的數(shù)據(jù)流組合與控制能力,但是其學(xué)習(xí)門檻一直很高,本次分享期望從一些特別的角度解讀它在業(yè)務(wù)中的使用,而不是從API角度去講解。,需要的朋友可以參考下
    2019-06-06
  • 理解Javascript文件動態(tài)加載

    理解Javascript文件動態(tài)加載

    這篇文章主要幫助大家理解Javascript文件動態(tài)加載,解決了Javascript文件動態(tài)加載時出現(xiàn)的錯誤,感興趣的小伙伴們可以參考一下
    2016-01-01
  • js實現(xiàn)表單提交后不重新刷新當(dāng)前頁面

    js實現(xiàn)表單提交后不重新刷新當(dāng)前頁面

    本文介紹了如何通過js實現(xiàn)表單提交后不重新刷新當(dāng)前頁面的方法實例.既提交了FORM保存了數(shù)據(jù),頁面也不會跳轉(zhuǎn),很實用。需要的朋友可以參考下
    2016-11-11
  • js遍歷json對象所有key及根據(jù)動態(tài)key獲取值的方法(必看)

    js遍歷json對象所有key及根據(jù)動態(tài)key獲取值的方法(必看)

    下面小編就為大家?guī)硪黄猨s遍歷json對象所有key及根據(jù)動態(tài)key獲取值的方法(必看)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • javascript將url中的參數(shù)加密解密代碼

    javascript將url中的參數(shù)加密解密代碼

    本文給大家分享一段給url參數(shù)加密解密的javascript代碼,非常的好用,有需要的小伙伴直接拿走吧
    2014-11-11
  • JS中多層次排序算法的實現(xiàn)代碼

    JS中多層次排序算法的實現(xiàn)代碼

    這篇文章主要給大家介紹了關(guān)于JS中多層次排序算法的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • JS中forEach()和map()的區(qū)別講解

    JS中forEach()和map()的區(qū)別講解

    forEach和map方法都是基于數(shù)組的迭代器實現(xiàn)的,它們的主要區(qū)別在于對回調(diào)函數(shù)的處理方式,這篇文章主要介紹了JS中forEach()和map()的區(qū)別,需要的朋友可以參考下
    2024-02-02
  • iframe與主框架跨域相互訪問實現(xiàn)方法

    iframe與主框架跨域相互訪問實現(xiàn)方法

    今天正好需要用到iframe 與主框架相互訪問的實現(xiàn)方法,正好看到了這篇文章,確實不錯,特分享一下,需要的朋友可以參考下
    2017-09-09
  • JavaScript隨機(jī)打亂數(shù)組順序之隨機(jī)洗牌算法

    JavaScript隨機(jī)打亂數(shù)組順序之隨機(jī)洗牌算法

    這篇文章主要介紹了JavaScript隨機(jī)打亂數(shù)組順序之隨機(jī)洗牌算法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • 使用純原生JS實現(xiàn)大文件分片上傳

    使用純原生JS實現(xiàn)大文件分片上傳

    前段時間在工作中接觸到了文件上傳的內(nèi)容,但業(yè)務(wù)中實現(xiàn)的功能比較簡單,于是我想著能不能使用純原生的方式實現(xiàn)一個大文件的上傳DEMO,從而在本質(zhì)上學(xué)習(xí)大文件上傳的思路,本教程使用純原生的html+node.js實現(xiàn),需要的朋友可以參考下
    2024-06-06

最新評論