>  기사  >  웹 프론트엔드  >  JavaScript에서 객체를 포함하는 배열에 대해 `typeof`가 \"Object\"를 반환하는 이유는 무엇입니까?

JavaScript에서 객체를 포함하는 배열에 대해 `typeof`가 \"Object\"를 반환하는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-03 12:26:29841검색

Why Does `typeof` Return

모순 이해: 객체가 포함된 typeof 배열이 "객체"를 반환하는 이유

개발자는 배열에서 typeof를 호출할 때 놀라운 현상에 직면할 수 있습니다. 개체를 포함하는 경우 설명할 수 없이 "배열" 대신 "개체"를 반환합니다. 이 기사에서는 모순처럼 보이는 이 동작에 대해 자세히 설명합니다.

예를 검토하여 문제를 설명하겠습니다.

<code class="javascript">$.ajax({
    url: 'http://api.twitter.com/1/statuses/user_timeline.json',
    data: { screen_name: 'mick__romney'},
    dataType: 'jsonp',
    success: function(data) {
        console.dir(data); //Array[20]
        alert(typeof data); //Object
    }
});</code>

console.dir(data)는 변수를 배열, typeof로 올바르게 식별합니다. data는 부적절하게 "Object"를 반환합니다.

이 설명은 JavaScript의 독특한 사양에 있습니다. 여기서 typeof 연산자는 개체의 유형을 반환합니다. 객체의 내부 [[클래스]] 속성. 배열의 경우 [[Class]] 속성이 "Array"로 설정되지만, 객체로 둘러싸여 있으면 [[Class]] 속성이 "Object"로 변경됩니다.

정확한 유형 검사를 위해 , 개발자는 다양한 접근 방식을 사용할 수 있습니다.

  • 배열의 데이터 인스턴스: 변수가 배열의 인스턴스인지 확인합니다. type.
  • Array.isArray(data): 객체가 배열인지 확인하기 위해 특별히 설계된 메서드입니다.
  • Object.prototype.toString.call(data) == '[object Array ]': 배열 감지를 위해 안정적이고 널리 사용되는 방법입니다.
  • $.isArray(data): 다음을 확인하도록 설계된 jQuery 전용 함수입니다.

개발자는 이러한 특징을 이해하고 이러한 기술을 활용함으로써 JavaScript 코드에서 객체 배열을 효과적으로 처리할 수 있습니다.

위 내용은 JavaScript에서 객체를 포함하는 배열에 대해 `typeof`가 \"Object\"를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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