typeof和instance(检测类型)

检测基本类型使用typeof

typeof是检测一个变量是不是基本数据类型的最佳工具,更具体一点,typeof是确定一个变量是字符串、数值、布尔值,还是undefined的最佳工具。
\color{red}{ (这里为什么不说null和object呢,因为如果变量的值是一个对象或null,typeof都会返回object) }

var s = 'jack'
var b = true
var i = 22
var u
var n = null
var o = new Object()

alert(typeof s)  // string
alert(typeof b)  // boolean
alert(typeof i)  // number
alert(typeof u)  // undefined
alert(typeof n)  // object
alert(typeof o)  // obejct

另外,typeof检测function会返回function

检测引用类型使用instanceof

检测引用类型使用instanceof,因为通常我们并不是想知道某个值是对象,而是想知道它是什么类型的对象。

var person = new Object()

alert(person instanceof Object)  // true
alert(person instanceof Array)  // false
alert(person instanceof RegExp)  // false

instanceof会根据原型链来识别,它检测后面参数\color{blue}{(构造函数)}prototype 是否存在于前面参数\color{blue}{(实例)}的原型链上,也就是判断变量是否是给定引用类型的实例,或者说是否继承,instanceof会返回truefalse
以下代码摘自 js中typeof用法和instanceof用法

// 定义构造函数
function C(){} 
function D(){} 

var o = new C();


o instanceof C; // true,因为 Object.getPrototypeOf(o) === C.prototype


o instanceof D; // false,因为 D.prototype 不在 o 的原型链上

o instanceof Object; // true,因为 Object.prototype.isPrototypeOf(o) 返回 true
C.prototype instanceof Object // true,同上

C.prototype = {};
var o2 = new C();

o2 instanceof C; // true

o instanceof C; // false,C.prototype 指向了一个空对象,这个空对象不在 o 的原型链上.

D.prototype = new C(); // 继承
var o3 = new D();
o3 instanceof D; // true
o3 instanceof C; // true 因为 C.prototype 现在在 o3 的原型链上
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。