JavaScript에서 객체 유형을 감지하는 연산자에는 typeof, 인스턴스of 및 객체의 생성자 속성이 포함됩니다.
1) typeof 연산자 typeof는 단항 연산자이며 반환 결과는 객체의 유형을 설명하는 문자열입니다. 피연산자. 예: "숫자", "문자열", "부울", "객체", "함수", "정의되지 않음"(변수가 존재하는지 확인하는 데 사용할 수 있음) 그러나 typeof에는 제한된 기능이 있으며 Date 및 RegExp 유형에 대해 "객체"를 반환합니다. 예:
typeof {}; // "object" typeof []; // "object" typeof new Date(); // "object"
따라서 객체와 기본 유형을 구별할 때만 유용합니다. 한 객체 유형을 다른 객체 유형과 구별하려면 다른 방법을 사용해야 합니다. 예: 객체의 인스턴스 연산자 또는 생성자 속성.
2) 인스턴스 오브 연산자. instanceof 연산자에서는 왼쪽의 피연산자가 객체이고 오른쪽의 피연산자가 객체 클래스의 이름 또는 생성자여야 합니다. object가 클래스나 생성자의 인스턴스이면 objectof 연산자는 true를 반환합니다. object가 지정된 클래스나 함수의 인스턴스가 아니거나 object가 null인 경우 false를 반환합니다. 예:
[] instanceof Array; // true [] instanceof Object; // true [] instanceof RegExp; // false new Date instanceof Date; // true
따라서, 객체가 배열 유형인지 확인하기 위해 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(){ var iframe_arr=new window.frames[0].Array; alert(iframe_arr instanceof Array); // false alert(iframe_arr.constructor == Array); // false } </script>
Ajaxian에서 프로토타입 체인 Object.prototype.toString() 전체에서 toString() 메서드를 호출하는 정확한 감지 방법을 보았습니다. 위의 크로스 프레임워크 문제를 해결할 수 있습니다. Object.prototype.toString(o)이 실행되면 다음 단계가 수행됩니다. 1) 객체 o의 클래스 속성을 얻습니다. 2) 연결 문자열: "[object "+result(1)+"]" 3) 결과(2) 반환 예:
Object.prototype.toString.call([]) // Return "[object Array]; "
Object.prototype.toString.call(/reg/ig); // Return "[object RegExp]"
이 방법으로 객체가 배열인지 확인하는 강력한 함수를 작성할 수 있습니다.
function isArray(arr){ return Object.prototype.toString.call(arr) === "[object Array]"; }
이 방법은 많은 외국 JavaScript 마스터에 의해 인정되었습니다. 이 방법은 곧 출시될 jQuery 1.3에서 배열을 감지하는 데 사용될 것입니다. 프로토타입.js의 관리자는 객체의 유형 이름을 얻는 데 사용되는 다음 함수를 작성했습니다.
/** * Returns internal [[Class]] property of an object * * Ecma-262, 15.2.4.2 * Object.prototype.toString( ) * * When the toString method is called, the following steps are taken: * 1. Get the [[Class]] property of this object. * 2. Compute a string value by concatenating the three strings "[object ", Result (1), and "]". * 3. Return Result (2). * * __getClass(5); // => "Number" * __getClass({}); // => "Object" * __getClass(/foo/); // => "RegExp" * __getClass(''); // => "String" * __getClass(true); // => "Boolean" * __getClass([]); // => "Array" * __getClass(undefined); // => "Window" * __getClass(Element); // => "Constructor" * */ function __getClass(object){ return Object.prototype.toString.call(object).match(/^\[object\s(.*)\]$/)[1]; };
다양한 객체 유형을 감지하도록 확장하세요.
var is ={ types : ["Array", "Boolean", "Date", "Number", "Object", "RegExp", "String", "Window", "HTMLDocument"] }; for(var i = 0, c; c = is.types[i ++ ]; ){ is[c] = (function(type){ return function(obj){ return Object.prototype.toString.call(obj) == "[object " + type + "]"; } )(c); } alert(is.Array([])); // true alert(is.Date(new Date)); // true alert(is.RegExp(/reg/ig)); // true
위 내용은 JavaScript가 연산자와 속성을 사용하여 객체 유형을 결정하는 방법 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!