2.NaN
特殊值NaN返回的是 “number”
typeof NaN // “number”
3 复杂数据类型
而复杂数据类型里,除了函数返回了"function"其他均返回“object”
typeof({a:1}) // “object” 普通对象直接返回“object”
typeof [1,3] // 数组返回"object"
typeof(new Date) // 内置对象 “object”
函数返回"function"
typeof function(){} // “function”
所以我们可以发现,typeof可以判断基本数据类型,但是难以判断除了函数以外的复杂数据类型。于是我们可以使用第三种方法,通常用来判断复杂数据类型,也可以用来判断基本数据类型。
obj instanceof Object
可以左边放你要判断的内容,右边放类型来进行JS类型判断,只能用来判断复杂数据类型,因为instanceof 是用于检测构造函数(右边)的 prototype 属性是否出现在某个实例对象(左边)的原型链上。
[1,2] instanceof Array // true
(function(){}) instanceof Function // true
({a:1}) instanceof Object // true
(new Date) instanceof Date // true
obj instanceof Object方法也可以判断内置对象。
缺点:在不同window或者iframe间,不能使用instanceof。
Object.property.toString.call (最实用)
它返回"[object, 类型]",注意返回的格式及大小写,前面是小写,后面是首字母大写。
基本数据类型都能返回相应的类型。
Object.prototype.toString.call(999) // “[object Number]”
Object.prototype.toString.call(‘’) // “[object String]”
Object.prototype.toString.call(Symbol()) // “[object Symbol]”
Object.prototype.toString.call(42n) // “[object BigInt]”
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频**
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
[外链图片转存中…(img-3RhxNubM-1710924426553)]