JavaScript에서 `instanceof`가 리터럴에 대해 `false`를 반환하는 이유는 무엇입니까?

DDD
풀어 주다: 2024-11-03 22:39:31
원래의
770명이 탐색했습니다.

Why Does `instanceof` Return `false` for Literals in JavaScript?

Instanceof와 리터럴의 미스터리

Instanceof 연산자가 일부 리터럴에 대해 false를 반환하는 이유는 무엇입니까?

JavaScript에서, instanceof 연산자는 객체가 특정 클래스나 클래스 계층의 인스턴스인지 확인합니다. 그러나 특정 리터럴에 적용하면 예기치 않은 동작이 발생합니다.

문자열, 숫자, 부울과 같은 리터럴은 클래스를 통해 생성되지 않고 코드에서 직접 정의됩니다. 다음 예를 살펴보겠습니다.

"foo" instanceof String //=> false
"foo" instanceof Object //=> false

true instanceof Boolean //=> false
true instanceof Object //=> false

12.21 instanceof Number //=> false

// Array and Object literals are exceptions
[0,1] instanceof Array //=> true
{0:1} instanceof Object //=> true
로그인 후 복사

구별 이해

기본 요소와 객체:

  • 문자열과 같은 리터럴, 숫자와 부울은 기본 요소입니다. 클래스나 인스턴스와는 독립적으로 존재합니다.
  • new 키워드로 생성된 배열 및 객체와 같은 객체는 클래스의 인스턴스입니다.

Instanceof 및 Primitives

instanceof 연산자는 객체가 클래스의 인스턴스인지 아니면 그 자손인지만 확인합니다. 기본 요소는 클래스를 통해 생성되지 않으므로 리터럴 값이 클래스 유형과 일치하더라도 instanceof는 기본 리터럴에 대해 항상 false를 반환합니다.

예외: 배열 및 객체

배열 및 객체 리터럴은 이 동작에서 예외입니다. 클래스를 통해 생성되지는 않지만 여전히 각각 Array 및 Object 클래스의 인스턴스로 간주됩니다. 이는 언어의 역사적 특성일 가능성이 높습니다.

대체 테스트 방법

값이 특정 기본 유형인지 테스트하려면 대신 typeof 연산자를 사용해야 합니다. of instanceof:

typeof "foo" === "string" //=> true
typeof 12.21 === "number" //=> true
로그인 후 복사

결론

Instanceof는 어떤 클래스의 인스턴스도 아니기 때문에 원시 리터럴로 잘못된 동작을 합니다. 배열 및 객체 리터럴은 역사적 특성으로 인해 예외입니다. 프리미티브의 타입을 결정할 때, 인스턴스 오브(instanceof) 대신에 타입 오브(typeof)를 사용하는 것이 좋습니다.

위 내용은 JavaScript에서 `instanceof`가 리터럴에 대해 `false`를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿