1. <output id="hzk7v"><pre id="hzk7v"><address id="hzk7v"></address></pre></output>
      <output id="hzk7v"></output>
    2. <nav id="hzk7v"><i id="hzk7v"><em id="hzk7v"></em></i></nav>
    3. <listing id="hzk7v"><delect id="hzk7v"><em id="hzk7v"></em></delect></listing>

      JS判断两个数组或对象是否相同的方法示例

       更新时间£º2019年02月28日 08:49:11   作者£ºhuangpb0624   我要评论

      这篇文章主要介绍了JS判断两个数组或对象是否相同的方法,结合实例形式分析了javascript针对简单数组与对象进行判断的相关操作技巧,需要的朋友可以参考下

      本文实例讲述了JS判断两个数组或对象是否相同的方法¡£分享给大家供大家参考£¬具体如下£º

      JS 判断两个数组是否相同

      要判断2个数组是否相同£¬首先要把数组进行?#21028;}?#28982;后转换成字符串进行比较¡£

      JSON.stringify([1,2,3].sort()) === JSON.stringify([3,2,1].sort()); //true
      
      

      或者

      [1,2,3].sort().toString() === [3,2,1].sort().toString(); //true
      
      

      经验证£¬上述方法对复杂数组结构不适用¡£

      JS 判断两个对象是否相同

      这是网上某大神封装对比对象是否相同的 function¡£

      let cmp = ( x, y ) => {
      // If both x and y are null or undefined and exactly the same
          if ( x === y ) {
            return true;
          }
      // If they are not strictly equal, they both need to be Objects
          if ( ! ( x instanceof Object ) || ! ( y instanceof Object ) ) {
            return false;
          }
      //They must have the exact same prototype chain,the closest we can do is
      //test the constructor.
          if ( x.constructor !== y.constructor ) {
            return false;
          }
          for ( var p in x ) {
            //Inherited properties were tested using x.constructor === y.constructor
            if ( x.hasOwnProperty( p ) ) {
              // Allows comparing x[ p ] and y[ p ] when set to undefined
              if ( ! y.hasOwnProperty( p ) ) {
                return false;
              }
              // If they have the same strict value or identity then they are equal
              if ( x[ p ] === y[ p ] ) {
                continue;
              }
              // Numbers, Strings, Functions, Booleans must be strictly equal
              if ( typeof( x[ p ] ) !== "object" ) {
                return false;
              }
              // Objects and Arrays must be tested recursively
              if ( ! Object.equals( x[ p ], y[ p ] ) ) {
                return false;
              }
            }
          }
          for ( p in y ) {
            // allows x[ p ] to be set to undefined
            if ( y.hasOwnProperty( p ) && ! x.hasOwnProperty( p ) ) {
              return false;
            }
          }
          return true;
      };
      
      

      经检测£¬同样也不支持复杂数据结构的对象¡£

      一般情况下用的话上述2种方法已经够用了£¬拿来作比较的一般都是简单的数据结构¡£

      更多关于JavaScript相关内容?#34892;?#36259;的读者可查看本站专题£º¡¶JavaScript数组操作技巧总结¡·¡¢¡¶JavaScript遍历算法与技巧总结¡·¡¢¡¶javascript面向对象入门教程¡·¡¢¡¶JavaScript数学运算用法总结¡·¡¢¡¶JavaScript数据结构与算法技巧总结¡·及¡¶JavaScript错误与调试技巧总结¡·

      希望本文所述对大家JavaScript程序设计?#20852;?#24110;助¡£

      相关文章

      最新评论

      3dÊÔ»úºÅÖвÊÍø

        1. <output id="hzk7v"><pre id="hzk7v"><address id="hzk7v"></address></pre></output>
          <output id="hzk7v"></output>
        2. <nav id="hzk7v"><i id="hzk7v"><em id="hzk7v"></em></i></nav>
        3. <listing id="hzk7v"><delect id="hzk7v"><em id="hzk7v"></em></delect></listing>

            1. <output id="hzk7v"><pre id="hzk7v"><address id="hzk7v"></address></pre></output>
              <output id="hzk7v"></output>
            2. <nav id="hzk7v"><i id="hzk7v"><em id="hzk7v"></em></i></nav>
            3. <listing id="hzk7v"><delect id="hzk7v"><em id="hzk7v"></em></delect></listing>