> 웹 프론트엔드 > JS 튜토리얼 > JavaScript_Basic 지식에서 개체 유형을 결정하는 여러 방법 요약

JavaScript_Basic 지식에서 개체 유형을 결정하는 여러 방법 요약

WBOY
풀어 주다: 2016-05-16 17:16:17
원래의
1121명이 탐색했습니다.

JavaScript에서 객체 유형을 감지하는 연산자는 typeof, instanceof 및 객체의 생성자 속성입니다.

1) typeof 연산자 typeof는 단항 연산자이며, 반환 결과는 피연산자의 유형을 설명하는 문자열입니다. 예: "숫자", "문자열", "부울", "객체", "함수", "정의되지 않음"(변수 존재 여부를 확인하는 데 사용할 수 있음) 그러나 typeof에는 제한된 기능이 있으며 Date 및 RegExp 유형에 대해 "객체"를 반환합니다. 예:

typeof {}; // "객체"
typeof []; // "객체"
typeof new Date();

따라서 객체와 기본 유형을 구별할 때만 유용합니다. 한 객체 유형을 다른 객체 유형과 구별하려면 다른 방법을 사용해야 합니다. 예: 객체의 인스턴스 연산자 또는 생성자 속성.

2) 인스턴스 오브 연산자. instanceof 연산자를 사용하려면 왼쪽 피연산자가 객체이고 오른쪽 피연산자가 객체 클래스의 이름 또는 생성자여야 합니다. object가 클래스나 생성자의 인스턴스이면 objectof 연산자는 true를 반환합니다. object가 지정된 클래스나 함수의 인스턴스가 아니거나 object가 null인 경우 false를 반환합니다. 예:

[] 인스턴스 오브 배열; // 참

[] 인스턴스 오브 RegExp; // 거짓
새 날짜 인스턴스

따라서 인스턴스 오브 연산자를 사용하여 객체가 배열 유형인지 확인할 수 있습니다.

function isArray(arr){

배열 인스턴스 반환

}

3) 생성자 속성.

JavaScript에서 각 개체에는 개체를 초기화하는 생성자를 참조하는 생성자 속성이 있으며, 이는 알 수 없는 개체의 유형을 결정하는 데 자주 사용됩니다. 예를 들어, 원하는 값이 주어지면 typeof 연산자를 사용하여 그것이 기본 값인지 객체인지 확인합니다. 객체인 경우 생성자 속성을 사용하여 해당 유형을 결정할 수 있습니다. 따라서 배열을 판단하는 함수는 다음과 같이 작성할 수도 있습니다. function isArray(arr){

return typeof arr == "object" && arr.constructor == Array;

많은 경우, 객체가 배열인지 여부를 감지하기 위해 객체의 인스턴스 오브 연산자나 생성자 속성을 사용할 수 있습니다. 예를 들어, 많은 JavaScript 프레임워크는 이 두 가지 방법을 사용하여 객체가 배열 유형인지 확인합니다. 그러나 크로스 프레임 페이지에서 배열을 감지하면 실패합니다. 그 이유는 서로 다른 프레임(iframe)에서 생성된 배열이 프로토타입 속성을 서로 공유하지 않기 때문입니다. 예:


코드 복사

코드는 다음과 같습니다.<script></span>window.onload =function(){</div>var iframe_arr=new window.frames[0].Array;<div class="codebody" id="code48389">alert(iframe_arr instanceof Array) // false<br>alert(iframe_arr.constructor == Array) ; // false <br>}<br></script>


프로토타입 체인 전체에서 toString() 메서드를 호출하는 정확한 감지 방법을 Ajaxian에서 보았습니다: Object.prototype.toString (). 위의 크로스 프레임워크 문제를 해결할 수 있습니다. Object.prototype.toString(o)이 실행되면 다음 단계가 수행됩니다. 1) 객체 o의 클래스 속성을 얻습니다. 2) 연결 문자열: "[object " result(1) "]" 3) 결과(2) 반환 예:

Object.prototype.toString.call([]); // "[객체 배열]"을 반환합니다.
Object.prototype.toString.call(/reg/ig); // "[객체 RegExp]"를 반환합니다.
이런 방법으로 객체가 배열인지 확인하는 강력한 함수를 작성할 수 있습니다.



코드 복사

코드는 다음과 같습니다:function isArray(arr){ return Object.prototype.toString.call(arr) === "[object Array]";
}


이 방법은 많은 외국 JavaScript 마스터에 의해 인정되었으며 향후 jQuery 1.3에서 배열을 감지하는 데 사용될 것입니다. 프로토타입.js의 관리자는 객체의 유형 이름을 얻는 데 사용되는 다음 함수를 작성했습니다.



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