关于javascript中的typeof和instanceof介绍
typeof用来检测给定变量的数据类型(也可叫做基本类型,基本数据类型。包含undefined、boolean、string、number、object、function)
var message = "so easy";
alert(typeof message); //"string"
alert(typeof 12); //"number"
可以这样记忆:typeof是用来判断不是用new创建的“变量”。
instanceof用来检测对象的类型(也可叫做引用类型。包含Object、Array、Date、RegExp、Function、基本包装类型(含Boolean、Number、String))
var numberObject = new Number(10);
var numberValue = 10;
alert(typeof numberObject); //"object"
alert(typeof numberValue); //"number"
alert(numberObject instanceof Number); //true
alert(numberValue instanceof Number); //false
numberValue是number基础数据类型,不属于任何引用类型。
numberObject是object基础数据类型,属于Number引用类型(所有引用类型都从Object引用类型继承而来)。
可以这样记忆:instanceof检测的都是用new创建的“对象”。而没有通过new创建出来的“变量”不属于任何一个引用类型。用typeof检测用new创建的“对象”始终返回的是“object引用类型”.
isPrototypeOf()方法用来检测原型和实例的关系。instanceof同样也可以检测。只要是原型链中出现过的原型,都可以说是该原型链所派生的实例的原型。
var person = new Person(); //Person继承与Object
alert(Person.prototype.isPrototypeOf(person)); //true
alert(Object.prototype.isPrototypeOf(person)); //true
- 详解JavaScript中typeof与instanceof用法
- Javascript typeof与instanceof的区别
- JavaScript类型检测之typeof 和 instanceof 的缺陷与优化
- 谈谈我对JavaScript中typeof和instanceof的深入理解
- 浅谈javascript中的instanceof和typeof
- JavaScript中instanceof与typeof运算符的用法及区别详细解析
- JS中typeof与instanceof之间的区别总结
- javascript之typeof、instanceof操作符使用探讨
- javascript instanceof,typeof的区别
- javascript instanceof 与typeof使用说明
- 菜鸟也能搞懂js中typeof与instanceof区别
相关文章
移动端自适应flexible.js的使用方法(不用三大框架,仅写一个单html页面使用)推荐
这篇文章主要介绍了移动端自适应flexible.js使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-04-04
最新评论