instanceof和typeof运算符的区别详解

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了instanceof和typeof运算符的区别详解相关的知识,希望对你有一定的参考价值。

一.instanceof运算符:
       此运算符可以判断一个变量是否是某个对象(类)的实例,返回值是布尔类型的。
想要理解它的作用,必须对面向对象有所理解:

  代码实例如下:


var str=new String("antzone");  
console.log(str instanceof String);

  以上代码会输出true,因为str是对象String的对象实例。
一般说来只有使用构造函数创建的对象才会返回true,否则返回false,不过数组是一个例外,都会返回true。


二.typeof运算符:
此运算符可以返回一个字符串,用语说明元算数的类型,它的返回值有如下可能:

  代码如下:

number,boolean,string,function,object,undefined

  实例 代码如下:


var str=new String("antzone"); 
var strTwo="antzone";  
console.log(typeof str); 
console.log(typeof strTwo);

  在以上代码中,第一个可以输出准确的类型"string",第二个确是"object",并不精准。
       一般来说使用typeof的操作是直接量形式的话能够返回准确的结果,如果是使用构造函数创建的对象则会返回"object",不过对于数组来说是个例外,无论是否是直接量都会返回"object"。

参考技术A 一.instanceof运算符:
此运算符可以判断一个变量是否是某个对象(类)的实例,返回值是布尔类型的。
想要理解它的作用,必须对面向对象有所理解:
代码实例如下:

.代码如下:

var str=new String("antzone");
console.log(str instanceof String);

以上代码会输出true,因为str是对象String的对象实例。
一般说来只有使用构造函数创建的对象才会返回true,否则返回false,不过数组是一个例外,都会返回true。

二.typeof运算符:
此运算符可以返回一个字符串,用语说明元算数的类型,它的返回值有如下可能:

.代码如下:

number,boolean,string,function,object,undefined

先看一段代码实例:

.代码如下:

var str=new String("antzone");
var strTwo="antzone";
console.log(typeof str);
console.log(typeof strTwo);

在以上代码中,第一个可以输出准确的类型"string",第二个确是"object",并不精准。
一般来说使用typeof的操作是直接量形式的话能够返回准确的结果,如果是使用构造函数创建的对象则会返回"object",不过对于数组来说是个例外,无论是否是直接量都会返回"object"。本回答被提问者和网友采纳
参考技术B var str=new String("antzone"); var strTwo="antzone";  console.log(typeof str); console.log(typeof strTwo);

第一个可以输出准确的类型"object",第二个确是"string"

以上是关于instanceof和typeof运算符的区别详解的主要内容,如果未能解决你的问题,请参考以下文章

Js 中 typeof 与 instanceof 的区别

typeof和instanceof的区别

typeof和instanceof的区别

tips instanceof运算符和typeof运算符的区别

typeof()和instanceof的用法区别

javascript typeof 和 instanceof 的区别和联系