웹 프론트엔드 JS 튜토리얼 JavaScript_Basic 지식에서 typeof 및 instanceof 연산자 사용에 대한 토론

JavaScript_Basic 지식에서 typeof 및 instanceof 연산자 사용에 대한 토론

May 16, 2016 pm 05:33 PM
instanceof typeof 연산자

JavaScript 코드를 작성할 때 typeof와 instanceof 두 연산자가 때때로 사용되므로 반드시 사용해야 합니다. 하지만! 이를 사용할 때 원하는 결과를 직접 얻는 것은 항상 어렵습니다. 일반적으로 "이 두 연산자는 아마도 JavaScript의 가장 큰 디자인 결함일 것입니다. 왜냐하면 원하는 결과를 얻는 것이 거의 불가능하기 때문입니다"
typeof
설명: typeof는 표현식의 데이터 유형 문자열을 반환하며, 반환 결과는 숫자, 부울, 문자열, 객체, 정의되지 않음, 함수를 포함한 js의 기본 데이터 유형입니다.
설명으로 볼 때 문제가 없는 것 같습니다.

다음 코드는 숫자 변수를 작성하고 typeof 이후의 결과는 "number"입니다.

코드 복사 코드는 다음과 같습니다.

var a = 1; .log( typeof(a)); //=>number

Number 유형의 생성자를 사용하여 변수를 생성하는 경우 typeof 이후의 결과는 "object"입니다.

코드 복사 코드는 다음과 같습니다.
var a = new Number(1);
console.log(typeof(a)); //=>object

위 두 가지 출력 결과는 문제가 없어 보이는데, 이는 책에서 나온 당연한 이야기인 것 같습니다. . 왜냐하면 자바스크립트는 이런 식으로 설계되었기 때문입니다.

하지만! 문제는 typeof가 호출되기 때문에 변수가 값을 사용하여 직접 생성되었거나 유형 생성자를 사용하여 생성되었는지 여부에 관계없이 변수의 유형을 정확하게 반환해야 한다는 것입니다. 내가 당신을 또 무엇에 이용해야 합니까?
다음의 경우:

코드 복사 코드는 다음과 같습니다.
var a = 1;
var b = new Number(1);

정확히 말하면 a와 b 변수의 유형이 Number여야 원하는 결과를 얻을 수 있습니다.
정확한 유형 정보는 Object.prototype에 정의된 toString 메서드를 사용하여 얻은 변수의 내부 속성 [[Class]] 값에 저장됩니다.

유형 정보 가져오기:

코드 복사 코드는 다음과 같습니다.
var a = 1;
var b = new Number(1);
console.log(Object.prototype.toString.call(a))
console.log(Object.prototype.toString. call(b ));

출력:

코드 복사 코드는 다음과 같습니다.
[객체 번호]
[객체 번호]

이미 매우 간단하지 않습니까? 약간의 처리를 수행하여 직접적인 결과를 얻어보겠습니다.

코드 복사 코드는 다음과 같습니다.
var a = 1
var b = new; 번호(1);
console.log( Object.prototype.toString.call(a).slice(8,-1))
console.log(Object.prototype.toString.call(b). Slice(8,-1));

출력:
Number
Number
원하는 결과입니다.
더 나은 사용을 위해 변수가 특정 유형인지 확인하는 방법을 캡슐화합니다.

function is(obj,type) {
var clas = Object.prototype.toString.call(obj).slice(8, -1)
return obj !== un Defined && obj !== null && clas === type;
}

몇 가지 변수를 정의하고 테스트해 보겠습니다.

코드 복사 코드는 다음과 같습니다.
var a1=1; a2=Number(1 );
var b1="hello";
var b2=new String("hello")
var c1=[1,2,3]; =new Array(1 ,2,3);
console.log("a1의 유형:" typeof(a1))
console.log("a2의 유형:" typeof(a2)); console.log(" b1의 유형:" typeof(b1));
console.log("b2의 유형:" typeof(b2))
console.log("c1의 유형:" typeof(c1)) ;
console .log("c2's typeof:" typeof(c2));
출력:
a1의 typeof:number
a2의 typeof:object
b1의 typeof:string
b2의 typeof :object
c1의 typeof:object
c2의 typeof:object


우리가 사용하는 새로 생성된 함수는 다음과 같습니다.
코드 복사 코드는 다음과 같습니다.

console.log("a1은 숫자:" is(a1,"Number"))
console.log("a2는 숫자:" is(a2,"Number"))
console .log( "b1은 문자열입니다:" is(b1,"String"));
console.log("b2는 문자열입니다:" is(b2,"String"))
console.log(" c1은 배열입니다:" is(c1,"Array"));
console.log("c2는 배열입니다:" is(c2,"Array"));
출력:
a1은 숫자입니다: true
a2는 숫자:true
b1은 문자열:true
b2는 문자열:true
c1은 배열:true
c2는 배열:true

참고: typeof 실제 사용은 변수가 정의되었는지 또는 값이 할당되었는지 감지하는 것입니다.
instanceof
설명: 개체가 특정 데이터 유형인지 또는 변수가 개체의 인스턴스인지 확인합니다.
instanceof 연산자는 두 개의 내장 유형 변수를 비교할 때 무력하며 결과에도 만족하지 못할 것입니다.
코드 복사 코드는 다음과 같습니다.

console.log("abc" instanceof String ); / / false
console.log("abc" instanceof Object); // false
console.log(new String("abc") instanceof String) // true
console.log( new String("abc")instanceofObject); // true

사용자 정의 개체를 비교할 때만 관계를 정확하게 반영합니다.
코드 복사 코드는 다음과 같습니다.

function Person() {}
function Man( ) {}
Man.prototype = new Person();
console.log(new Man()instanceofMan); // true
console.log(new Man()instanceofPerson) ; // 참
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

인스턴스오브는 무엇을 하는가? 인스턴스오브는 무엇을 하는가? Nov 14, 2023 pm 03:50 PM

instanceof의 기능은 객체가 특정 클래스의 인스턴스인지 또는 특정 인터페이스를 구현하는지 여부를 확인하는 것입니다. instanceof는 객체가 지정된 유형인지 확인하는 데 사용되는 연산자입니다. instanceof 연산자의 사용 시나리오: 1. 유형 검사: 객체의 특정 유형을 결정하여 다양한 유형에 따라 다른 논리를 수행하는 데 사용할 수 있습니다. 2. 인터페이스 판단: 객체가 인터페이스를 구현하는지 여부를 결정하는 데 사용할 수 있습니다. , 객체가 인터페이스를 구현하는지 여부를 확인하기 위해 인터페이스 정의는 해당 메서드를 호출합니다. 3. 하향 변환 등.

Linux 명령에서 '!' 연산자의 8가지 신비한 용도 Linux 명령에서 '!' 연산자의 8가지 신비한 용도 Jun 27, 2023 pm 12:51 PM

'!' 기호를 사용하는 대부분의 Linux 명령 사용법은 셸마다 다를 수 있습니다. 내가 제공하는 예제는 일반적으로 bash 셸에서 사용되지만 일부 다른 Linux 셸에서는 구현이 다를 수도 있고 '!' 기호의 특정 용도를 전혀 지원하지 않을 수도 있습니다. Linux 명령에서 '!' 기호의 놀랍고 신비한 용도에 대해 살펴보겠습니다. 1. 명령 번호를 사용하여 기록에서 명령을 실행합니다. 여러분이 알지 못할 수도 있는 것은 명령 기록에서 명령(이미 실행된 명령)을 실행할 수 있다는 것입니다. 먼저 'history' 명령을 실행하여 명령 번호를 찾습니다. linuxmi@linuxmi:~/www.linuxmi.

PHP의 모듈로 등호 연산자 사용법에 대해 자세히 알아보세요. PHP의 모듈로 등호 연산자 사용법에 대해 자세히 알아보세요. Mar 19, 2024 pm 12:54 PM

모듈로 등호 연산자(%)는 PHP에서 매우 일반적으로 사용되는 연산자이며 두 숫자를 나눈 나머지를 계산하는 데 사용됩니다. 이 기사에서는 모듈식 같음 연산자의 사용법을 더 자세히 살펴보고 독자의 이해를 돕기 위해 구체적인 코드 예제를 제공합니다. 먼저 간단한 예를 살펴보겠습니다. 한 숫자를 다른 숫자로 나눈 나머지를 계산해야 합니다. $a=10;$b=3;$remainder=$a%$b;echo"10 나누기 3 나머지 이다: &

연산자 사용법의 SQL 연산자 사용법의 SQL Aug 04, 2023 pm 03:58 PM

SQL 연산자 사용: 1. 단일 열 일치, IN 연산자를 사용하여 열의 여러 값 일치. 2. 다중 열 일치, IN 연산자를 사용하여 여러 열의 값 일치; 3. 하위 쿼리, IN 연산자는 기본 쿼리 내에 중첩된 쿼리 문인 하위 쿼리와 함께 사용할 수도 있습니다.

Java에서 인스턴스 오브는 무엇을 의미합니까? Java에서 인스턴스 오브는 무엇을 의미합니까? Nov 13, 2023 pm 01:52 PM

Java에서 인스턴스of는 객체가 클래스의 인스턴스인지 클래스의 하위 클래스 인스턴스인지 확인하는 데 사용되는 이진 연산자입니다. 구문은 "객체 인스턴스오브 클래스"입니다. 여기서 객체는 객체입니다. 이름 또는 인터페이스 이름.

Java에서 instanceof 연산자를 사용하는 방법 Java에서 instanceof 연산자를 사용하는 방법 May 19, 2023 am 08:16 AM

개념 1. 이 연산자는 객체에 대해 연산을 수행하고 객체가 특정 유형(유형 또는 인터페이스 유형)인지 확인하는 데 사용됩니다. 형식 2. 계산기 왼쪽의 변수가 가리키는 객체가 연산자 오른쪽의 클래스나 인터페이스의 객체이면 결과는 참이다. (Objectreferencevariable)instanceof(class/interfacetype) 인스턴스 packagecom.verify_instanceof;publicclassTestInstanceOf{publicstaticvoidmain(String[]args){//다음 4줄의 코드를 사용하여 증명합니다.

php7에 두 개의 새로운 연산자가 추가되었습니다: '?->' 및 '??' php7에 두 개의 새로운 연산자가 추가되었습니다: '?->' 및 '??' Mar 21, 2023 pm 03:49 PM

이전 PHP 버전에서는 변수를 정의하지 않은 경우 변수를 직접 사용하면 정의되지 않은 변수 오류가 발생했습니다. 그러나 PHP7에서는 이 문제를 피하기 위해 몇 가지 새로운 기능을 사용할 수 있습니다. 이러한 새로운 기능에는 ?-> 및 ??라는 두 가지 새로운 연산자가 포함됩니다. 그들은 각각 두 가지 유형의 문제를 해결할 수 있습니다.

Java의 instanceof 연산자 Java의 instanceof 연산자 Sep 01, 2023 pm 08:01 PM

이 연산자는 객체 참조 변수에만 사용됩니다. 이 연산자는 객체가 특정 유형(클래스 유형 또는 인터페이스 유형)에 속하는지 여부를 확인합니다. instanceof 연산자는 -(Objectreferencevariable)instanceof(class/interfacetype)으로 작성됩니다. 연산자 왼쪽의 변수가 참조하는 객체가 오른쪽 클래스/인터페이스 유형의 IS-A 검사를 통과하면 결과는 다음과 같습니다. 사실이세요. 다음은 예입니다. 실시간 데모 예 publicclassTest{ publicstaticvoidmain(Stringargs[]){&nbs

See all articles