1) typeof 연산자
typeof는 단항 연산자이며, 반환 결과는 피연산자의 유형을 설명하는 문자열입니다. 예: "숫자", "문자열", "부울", "객체", "함수", "정의되지 않음"(변수가 존재하는지 확인하는 데 사용할 수 있음)
그러나 typeof에는 Date 및 RegExp 유형에 대해 "객체"를 반환하는 기능이 제한되어 있습니다. 예:
typeof {} // "object"
typeof []; // "object"
typeof new Date(); // "object"
따라서 객체와 기본 유형을 구별할 때만 유용합니다. . 한 객체 유형을 다른 객체 유형과 구별하려면 다른 방법을 사용해야 합니다. 예: 객체의 인스턴스 연산자 또는 생성자 속성.
2) 인스턴스 오브 연산자. instanceof 연산자를 사용하려면 왼쪽 피연산자가 객체이고 오른쪽 피연산자가 객체 클래스의 이름 또는 생성자여야 합니다. object가 클래스나 생성자의 인스턴스이면 objectof 연산자는 true를 반환합니다. object가 지정된 클래스나 함수의 인스턴스가 아니거나 object가 null인 경우 false를 반환합니다. 예:
[] 인스턴스 오브 배열; // true
[] 인스턴스 오브 RegExp; // false
new Date 인스턴스 // true;
따라서 objectof가 배열 유형인지 확인하기 위해 objectof 연산자를 사용할 수 있습니다.
function isArray(arr)
{
return arr instanceof Array; }
3) 생성자 속성.
JavaScript에서 각 객체에는 객체를 초기화하는 생성자를 참조하는 생성자 속성이 있습니다. 이는 알 수 없는 객체의 유형을 결정하는 데 자주 사용됩니다. 예를 들어 쿼리 값이 주어지면 typeof 연산자를 사용하여 해당 값이 기본 값인지 객체인지 확인합니다. 객체인 경우 생성자 속성을 사용하여 해당 유형을 결정할 수 있습니다. 따라서 배열을 판단하는 함수는 다음과 같이 작성할 수도 있습니다. function isArray(arr)
{
return typeof arr == "object" && arr.constructor == Array; >}
많은 경우, 객체가 배열인지 여부를 감지하기 위해 객체의 인스턴스 오브 연산자나 생성자 속성을 사용할 수 있습니다. 예를 들어, 많은 JavaScript 프레임워크는 이 두 가지 방법을 사용하여 객체가 배열 유형인지 확인합니다.
그러나 크로스 프레임 페이지에서 배열을 감지하면 실패합니다. 그 이유는 서로 다른 프레임(iframe)에서 생성된 배열이 프로토타입 속성을 서로 공유하지 않기 때문입니다. 예:
코드 복사
코드는 다음과 같습니다. <script> >window.onload =function(){ </div>var iframe_arr=new window.frames[0].Array; <div class="codebody" id="code54018">alert(iframe_arr instanceof Array) // false <br>alert(iframe_arr.constructor == Array) ; // false <br>} <br></script>
🎜>Ajaxian에서는 프로토타입 체인인 Object.prototype.toString() 전체에서 toString() 메서드를 호출하는 정확한 감지 방법을 보았습니다. 위의 크로스 프레임워크 문제를 해결할 수 있습니다.
Object.prototype.toString(o)이 실행되면 다음 단계가 수행됩니다.
1) 객체 o의 클래스 속성을 가져옵니다.
2) 연결 문자열: "[object " result(1) "]"
3) 결과(2) 반환
예:
Object.prototype.toString. call([]); // "[객체 배열]"을 반환합니다.
Object.prototype.toString.call(/reg/ig) // "[객체 RegExp]"를 반환합니다.
이런 식으로 , we 개체가 배열인지 확인하는 강력한 함수를 작성할 수 있습니다.
코드 복사
코드는 다음과 같습니다.
이 방법은 외국의 많은 JavaScript 마스터들에 의해 인정되었으며, 곧 출시될 jQuery 1.3에서는 이 방법이 배열 감지에 사용될 예정입니다.
prototype.js의 관리자는 객체의 유형 이름을 가져오는 데 사용되는 다음 함수를 작성했습니다.
코드 복사
코드는 다음과 같습니다.
/**
* 객체의 내부 [[클래스]] 속성을 반환합니다.
*
* Ecma-262, 15.2.4.2
* Object.prototype.toString( )
*
* 다음과 같은 경우 toString 메소드가 호출되면 다음 단계가 수행됩니다.
* 1. 이 객체의 [[Class]] 속성을 가져옵니다.
* 2. "[object ", Result (1) 및 "]" 세 문자열을 연결하여 문자열 값을 계산합니다.
* 3. 반환 결과(2).
*
* __getClass(5); // => "숫자"
* __getClass({}); // => "객체"
* __getClass(/foo/); // => "정규식"
* __getClass(''); // => "문자열"
* __getClass(true); // => "부울"
* __getClass([]); // => "배열"
* __getClass(undefine); // => "창"
* __getClass(Element); // => "생성자"
*
*/
function __getClass(object)
{
return Object.prototype.toString.call(object).match(/^[objects(.* )]$/)[1]
};
확장하여 다양한 개체 유형 감지:
var is =
{
types: ["Array", "Boolean", "Date", "Number" , "객체", "RegExp", "문자열", "창", "HTMLDocument"]
}
for(var i = 0, c; c = is.types[i ]; )
{
is[c] = (함수(유형)
{
반환 함수(obj)
{
return Object.prototype.toString.call(obj) == " [객체 " 유형 "]";
}
}
)(c);
}
alert(is.Array([])); // true
alert( is.Date(new Date)); // 참
alert(is.RegExp(/reg/ig)) // 참