>웹 프론트엔드 >JS 튜토리얼 >JavaScript에서 배열과 객체를 효율적으로 비교하는 방법은 무엇입니까?

JavaScript에서 배열과 객체를 효율적으로 비교하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-30 22:11:17290검색

How to Efficiently Compare Arrays and Objects in JavaScript?

JavaScript의 효율적인 배열 비교

소개

JavaScript의 배열 비교는 까다로울 수 있습니다. 비교 연산자(==)가 예상대로 작동하지 않으며 비교를 위해 배열을 JSON으로 변환하는 것이 비효율적일 수 있습니다. 다음은 효율적으로 어레이를 비교하기 위한 종합 가이드입니다.

어레이 비교

효율적인 어레이 비교를 수행하려면 다음 단계를 따르세요.

1 . 사용자 정의 Equals 메서드:

Array.prototype에서 equals라는 사용자 정의 메서드를 정의합니다. 이 방법은 배열의 각 요소를 재귀적으로 비교합니다.

Array.prototype.equals = function (array) {
  if (!array) return false;
  if (this === array) return true;
  if (this.length !== array.length) return false;

  for (let i = 0; i < this.length; i++) {
    if (
      this[i] instanceof Array &&
      array[i] instanceof Array
    ) {
      if (!this[i].equals(array[i])) return false;
    } else if (this[i] !== array[i]) {
      return false;
    }
  }
  return true;
};

2. 사용법:

equals 메소드를 사용하여 두 배열을 비교하려면 다음과 같이 그 중 하나에서 호출하면 됩니다.

[1, 2, [3, 4]].equals([1, 2, [3, 2]]) === false;

객체 비교

객체를 부분적으로 비교하는 것은 가능하지만 두 객체 인스턴스가 동일한 내용을 포함하더라도 결코 동일하지 않다는 점에 유의해야 합니다. 데이터.

1. 객체에 대한 사용자 정의 같음 방법:

Object.prototype.equals = function (object2) {
  for (let propName in this) {
    if (
      this.hasOwnProperty(propName) !==
      object2.hasOwnProperty(propName)
    ) {
      return false;
    } else if (
      typeof this[propName] !== typeof object2[propName]
    ) {
      return false;
    }
  }

  for (let propName in object2) {
    if (
      this.hasOwnProperty(propName) !==
      object2.hasOwnProperty(propName)
    ) {
      return false;
    } else if (
      typeof this[propName] !== typeof object2[propName]
    ) {
      return false;
    }

    if (!this.hasOwnProperty(propName)) continue;

    if (
      this[propName] instanceof Array &&
      object2[propName] instanceof Array
    ) {
      if (!this[propName].equals(object2[propName]))
        return false;
    } else if (
      this[propName] instanceof Object &&
      object2[propName] instanceof Object
    ) {
      if (!this[propName].equals(object2[propName]))
        return false;
    } else if (this[propName] !== object2[propName]) {
      return false;
    }
  }

  return true;
};

2. 사용법:

({ a: 1, foo: "bar", numberOfTheBeast: 666 }).equals({
  a: 1,
  foo: "bar",
  numberOfTheBeast: 666,
}) === false;

indexOf 및 포함이 포함된 중첩 배열

중첩 배열과 관련된 더 복잡한 경우에는 indexOf 및 포함 함수를 사용하여 검색할 수 있습니다. 중첩된 특정 개체에 대해

결론

이러한 기술을 따르면 JavaScript의 배열과 객체를 효율적으로 비교할 수 있어 일반적인 함정을 해결하고 이러한 비교를 자신있게 수행할 수 있습니다.

위 내용은 JavaScript에서 배열과 객체를 효율적으로 비교하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.