前端百题斩 [001]——typeof 和 instanceof
思虑良久,终于要动笔写“前端百题斩”了,虽然是百题斩,但目前仅“js、浏览器和网络”部分就确定了 100 个高能知识点与朋友们分享。写该系列文章的初衷是“让每位前端工程师掌握高频知识点,为工作助力”。希望爱学习的朋友们关注公众号“执鸢者”,用知识武装自己的头脑。
1.1 typeof
1.1.1 基础介绍
typeof
是一个运算符,其有两种使用方式:(1)typeof(表达式)
;(2)typeof 变量名
;返回值是一个字符串,用来说明变量的数据类型;所以可以用此来判断number
,string
,object
,boolean
,function
,undefined
,symbol
这七种类型,每种情况返回的内容如下表所示:
1.1.2 原理进阶
typeof
方法虽然很好用,但该方法有一定的局限性: 对于对象、数组、null
返回的值是object
。比如typeof(window)
,typeof(document)
,typeof(null)
返回的值都是object
,这是为什么呢?这就要从底层说起。js 在底层存储变量的时候,会在变量的机器码的低位 1-3 位存储其类型信息:
000
:对象;010
:浮点数;100
:字符串;110
:布尔值;1
:整数;特例:
(1)
null
所有机器码均为0
(2)
undefined
:用−2^30
整数来表示
typeof
就是通过机器码判断类型,由于 null 的所有机器码均为 0,该机器码和对象一样,因此直接被当作对象来看待,所以通过typeof
就不能够判断区分对象还有null
了。
1.1.3 实验
说了这么多,还没有进行验证,下面就逐一验证一下:
1.2 instanceof
1.2.1 基础介绍
instanceof
运算符用于检测构造函数的prototype
属性是否出现在某个实例对象的原型链上,返回值为布尔值,用于指示一个变量是否属于某个对象的实例。其语法如下所示:
1.2.2 原理进阶
instanceof
主要的实现原理就是只要右边变量的prototype
在左边变量的原型链上即可。因此,instanceof
在查找的过程中会遍历左边变量的原型链,直到找到右边变量的prototype
,如果查找失败,则会返回false
.步骤如下所示:
获取左边变量的隐式原型(即:__ proto __ ,可通过 Object.getPrototypeOf()获取);
获取右边变量的显示原型(即:prototype);
进行判断,比较 leftVal. __ proto __ . __ proto __ …… === rightVal.prototype,相等则返回 true,否则返回 false。
1.2.3 实验
上面讲述了 instanceof 的简单使用和其原理,下面简单使用一下并验证一下该原理:
1.如果觉得这篇文章还不错,来个分享、点赞吧,让更多的人也看到
2.关注公众号执鸢者,与号主一起斩杀前端百题。
版权声明: 本文为 InfoQ 作者【执鸢者】的原创文章。
原文链接:【http://xie.infoq.cn/article/a729f68f4d02901649c67f995】。文章转载请联系作者。
评论