>  기사  >  웹 프론트엔드  >  isArray() 함수(JavaScript의 여러 객체 유형 판단 방법)_javascript 기술

isArray() 함수(JavaScript의 여러 객체 유형 판단 방법)_javascript 기술

WBOY
WBOY원래의
2016-05-16 18:40:571125검색
1) typeof 연산자
typeof는 단항 연산자이며, 반환 결과는 피연산자의 유형을 설명하는 문자열입니다. 예: "숫자", "문자열", "부울", "객체", "함수", "정의되지 않음"(변수가 존재하는지 확인하는 데 사용할 수 있음)
그러나 typeof에는 Date 및 RegExp 유형에 대해 "객체"를 반환하는 기능이 제한되어 있습니다. 예:

typeof {}; // "객체"
typeof []; // "객체"
typeof new Date(); 따라서 객체와 기본 유형을 구별할 때만 유용합니다. 한 객체 유형을 다른 객체 유형과 구별하려면 다른 방법을 사용해야 합니다. 예: 객체의 인스턴스 연산자 또는 생성자 속성.


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)에서 생성된 배열이 프로토타입 속성을 서로 공유하지 않기 때문입니다. 예:




코드 복사

Object.prototype.toString. call([]); // "[객체 배열]"을 반환합니다.
Object.prototype.toString.call(/reg/ig) // "[객체 RegExp]"를 반환합니다.

이런 식으로 , we 개체가 배열인지 확인하는 강력한 함수를 작성할 수 있습니다.




코드 복사


코드는 다음과 같습니다.

function isArray(arr) { return Object.prototype.toString.call(arr) === "[객체 배열]" } 이 방법은 외국의 많은 JavaScript 마스터들에 의해 인정되었으며, 곧 출시될 jQuery 1.3에서는 이 방법이 배열 감지에 사용될 예정입니다.
prototype.js의 관리자는 객체의 유형 이름을 가져오기 위해 다음 함수를 작성했습니다.

function __getClass(object)
{
return Object.prototype.toString .call (object).match(/^[objects(.*)]$/)[1]
};

다양한 객체 유형을 감지하도록 확장됨:




코드 복사


코드는 다음과 같습니다.

is[c] = (function(type)
{
return function(obj)
{
return Object .prototype. toString.call(obj) == "[객체 " 유형 "]";
}
}
)(c)
}
alert(is.Array([ ])) ; // 참
alert(is.Date(new Date)); // 참
alert(is.RegExp(/reg/ig)) // 참

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