instanceof和typeof运算符的区别详解_jquery
程序员文章站
2022-06-01 17:13:12
...
一.instanceof运算符:
此运算符可以判断一个变量是否是某个对象(类)的实例,返回值是布尔类型的。
想要理解它的作用,必须对面向对象有所理解:
var str=new String("antzone");
console.log(str instanceof String);
number,boolean,string,function,object,undefined
var str=new String("antzone");
var strTwo="antzone";
console.log(typeof str);
console.log(typeof strTwo);
此运算符可以判断一个变量是否是某个对象(类)的实例,返回值是布尔类型的。
想要理解它的作用,必须对面向对象有所理解:
代码实例如下:
复制代码 代码如下:
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"。
推荐阅读
-
instanceof和typeof运算符的区别详解
-
jquery遍历之parent()和parents()的区别及parentsUntil()方法详解
-
Jquery中.bind()、.live()、.delegate()和.on()之间的区别详解
-
jquery中done和then的区别(详解)
-
Jquery中.bind()、.live()、.delegate()和.on()之间的区别详解
-
instanceof 和 typeof的区别
-
基于jquery的on和click的区别详解
-
jQuery Ajax的readyState和status的区别和使用详解
-
instanceof和typeof运算符的区别详解
-
jquery遍历之parent()和parents()的区别及parentsUntil()方法详解