>  기사  >  웹 프론트엔드  >  JS에서 변수가 배열, 함수 또는 객체인지 확인하는 방법에 대한 코드 설명

JS에서 변수가 배열, 함수 또는 객체인지 확인하는 방법에 대한 코드 설명

伊谢尔伦
伊谢尔伦원래의
2017-07-18 11:31:001107검색

Array

ECMAScript5의 Array.isArray는 IE9 이상에서 지원되는 배열을 판단하는 기본 방법입니다. 호환성상의 이유로 이 메서드가 없는 브라우저에서는 Object.prototype.toString.call(obj) === '[object Array]'를 대신 사용할 수 있습니다.

var isArray = Array.isArray || function(obj) {
    return Object.prototype.toString.call(obj) === '[object Array]';
}

JQ는 배열에서 지정된 값을 검색하고 해당 인덱스를 반환하는(찾을 수 없는 경우 -1 반환) 함수 jQuery.inArray(value, array)를 캡슐화합니다.
value 검색할 값입니다. array 검색할 배열입니다.

function inArray1(needle,array,bool){  
    if(typeof needle=="string"||typeof needle=="number"){  
        for(var i in array){  
            if(needle===array[i]){  
                if(bool){  
                    return i;  
                }  
                return true;  
            }  
        }  
        return false;  
    }  
}

Function

가장 간단하고 성능이 가장 좋은 방법은 typeof obj == 'function'입니다. 일부 브라우저 버전의 버그를 고려할 때 가장 안정적인 방법은 Object.prototype.toString.call(obj) === '[object Function]'입니다.

var isFunction = function(obj) {
    return Object.prototype.toString.call(obj) === '[object Function]';
}
if(typeof /./ != 'function' && typeof Int8Array != 'object') {
    isFunction = function(obj) {
        return typeof obj == 'function';
    }
}

Objects

JavaScript에서는 복합 유형도 객체이고, 함수도 객체입니다. 위의 두 가지에 typeof를 사용하면 각각 '객체'와 '함수'를 얻을 수 있습니다. 또한 typeof null도 'object'를 반환하므로 null 값은 제외해야 합니다.

아아아아

위 내용은 JS에서 변수가 배열, 함수 또는 객체인지 확인하는 방법에 대한 코드 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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