객체 평등의 복잡성
동일한 특성을 공유함에도 불구하고 겉보기에 동일해 보이는 두 객체는 JavaScript에서 동일하지 않은 상태로 유지됩니다. 아래 코드 조각을 보면 이 현상이 많은 사람들을 당황하게 했습니다.
var a = {}; var b = {}; console.log(a==b); //returns false console.log(a===b); //returns false
동등 연산자 이해
일반(==)과 엄격한 결과 간의 차이 (===) 항등 연산자는 유형 변환에 있습니다. 정규 동등성은 암시적 유형 변환을 수행하지만 엄격한 동등성은 그렇지 않습니다. 그러나 이 경우 두 변수는 모두 객체이므로 유형 변환은 관련이 없습니다.
객체 ID
객체 비교는 동일한 객체 참조를 비교할 때만 true로 평가되며, 사용된 항등 연산자와 관계없이. 즉, a == a, a == b(b가 a의 별칭인 경우), a != c(c가 다른 객체인 경우)입니다.
의미
이 독특한 동작은 객체 지향 프로그래밍에 영향을 미칩니다. 속성은 동일하지만 참조가 다른 두 객체는 동일한 실제 개체를 나타내더라도 동일하지 않은 것으로 간주됩니다.
예를 들어 데이터베이스에서 동일한 이름, 주소 및 이름을 가진 동일한 사람을 나타내는 두 객체는 전화번호는 개체 참조가 다르기 때문에 동일한 것으로 간주되지 않습니다. 이로 인해 개체 비교를 수행할 때 혼란스러운 결과가 발생할 수 있습니다.
솔루션
두 개체의 속성을 비교해야 하는 경우 타사 라이브러리를 사용하거나 각 속성을 개별적으로 확인하는 맞춤형 비교 기능.
위 내용은 두 개의 동일한 JavaScript 개체가 다른 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!