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

Posted

tags:

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

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

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

	var str=new String("foodoir"); 
	var str2="foodoir";  
	console.log(str instanceof String); 	//true
	console.log(str2 instanceof String);	//false

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

	var arr = [1,2,3];
	var arr2 = new Array(1,2,3);
	console.log(str instanceof String);		//true
	console.log(str instanceof String);		//true


二、typeof运算符:
  此运算符可以返回一个字符串,用语说明元算数的类型,它的返回值有如下可能:
          number,boolean,string,function,object,undefined

  实例 代码如下:

    var str=new String("foodoir");
    var str2="foodoir";  
    console.log(typeof str);   //object
    console.log(typeof str2);  //string

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

    var arr = [1,2,3];
    var arr2 = new Array(1,2,3);
    console.log(typeof arr);
    console.log(typeof arr2);

 

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

Js 中 typeof 与 instanceof 的区别

instanceof和typeof运算符的区别详解

关于JavaScript中的typeof与instanceof

typeof和instanceof的认识

instanceof和typeof运算符的区别详解

typeof和instanceof的区别