视频笔记,欢迎各种补充与纠错0.0

来源:1-5 [JavaScript]类型检测

_Doogie

2016-09-05 15:07

1.类型检测
1)typeof(基本类型检测)
对所有基本类型的返回值
typeof Number	//“Number”
typeof String	//"string"
typeof Boolean	//"boolean"
typeof null	//"object"
typeof undefined	//"undefined"
typeof object	//"object"
对函数类型的返回值
typeof function	//"function"

2)由于typeof只适用于判断基本类型,对object,Date,Array进行检测时只会统一返回“object”(很显然这不是我们想要的,我们想知道它的具体类型),这时就要用到instanceof了,instanceof在检测对象时会返回具体类型,如:
new array() instanceof Array	//true
new Date() instanceof Date	//true
...
如果想用instanceof去检测基本类型只会统一返回false,另外由于instanceof是基于原型链的,所以有下列结果:
//定义父类
function Parent(){}
//定义子类
function Child(){}
//让子类继承父类
Child.prototype = new Parent();
//此时再new一个子类实例,使用instanceof
new Child() instanceof Child;	//true
new Child() instanceof Parent	//true
通过原型链索引,new的是子类实例,子类继承父类,所以子类实例既是子类类型又属于父类类型
PS:instanceof在跨iframe或者window时由于存在多个window对象,所以在使用instanceof检测时会返回false

3)object.prototype.toString
说实话- -,这个没用过,所以涨知识了
Object.prototype.toString.apply([])	//"[Object Array]"
Object .prototype.toString.apply(function(){});	//"[Object function]"
Object .prototype.toString.apply(null);	//"[Object null]'
...
PS:ie6/7/8下存在兼容性问题,在检测null时会返回object

4)constructor构造器
每个对象都有个constructor属性,它指向该对象的构造函数类型,不过该属性的值可以被改写的,所以用它的判断并不可靠

5)duck type
百度了为啥叫“鸭子类型”,有这样的话:“当看到一只鸟走起来像鸭子、游泳起来像鸭子、叫起来也像鸭子,那么这只鸟就可以被称为鸭子。”
大概意思就是说当某个对象具备某种类型的特征或者行为时就可以被判断为某种类型,不知道是不是“能力检测”那种意思- -


写回答 关注

3回答

  • 我们都变了
    2017-02-26 19:47:07

    手动点赞

  • 慕粉2140547623
    2017-01-10 19:05:04

    typeof Number
    "function"

  • 瑜伽兔子
    2016-09-05 21:41:29

    厉害 佩服

JavaScript深入浅出

由浅入深学习JS语言特性,且解析JS常见误区,从入门到掌握

281112 学习 · 1020 问题

查看课程

相似问题