js数据类型分析

  • 时间:2018-06-06 01:57 作者:野生前端工程师 来源:野生前端工程师 阅读:176
  • 扫一扫,手机访问
摘要:基本数据类型undefinednullNumberStringBooleanSymbol其中Symbol是在ES6中新加入的基本类型, 相关链接;先使用类型检测方法来测试一下需要注意:typeof null 返回的是object而不是null; 相关文档说这是当初设计的一个BUG,以下是引使用:在

基本数据类型

  • undefined

  • null

  • Number

  • String

  • Boolean

  • Symbol

其中Symbol是在ES6中新加入的基本类型, 相关链接;

先使用类型检测方法来测试一下

js数据类型分析

需要注意:

typeof null 返回的是object而不是null; 相关文档说这是当初设计的一个BUG,以下是引使用:

在 JavaScript 最初的实现中,JavaScript 中的值是由一个表示类型的标签和实际数据值表示的。对象的类型标签是0。因为 null 代表的是空指针(大多数平台下值为0x00),因而,null的类型标签也成为了0,typeof null就错误的返回了"object".

引使用地址: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/typeof

引使用类型

Object

Function

Array

Date

Math

Number

Boolean

String

Array

RegExp

先来看一下检测结果

js数据类型分析

需要注意:

js数据类型分析

基本类型的引使用类型的区别

使用Number类型来做个实验,来解释下为什么 new Number(1) !== 1

js数据类型分析

获取n1与n2的原型

js数据类型分析

通过比较,发现尽管n1与n2的原型都是Number。但是通过字面量公告的变量testNumber,尽管属于Number类型,但是n1的原型中并未包含Number与Object的实例.

正是由于n1不包含Object的实例, 所以在进行属性操作时会无效。

实际编码中特别需要注意: 变量所存储的只是对象的指针,而不是对象的本身。

js数据类型分析

结论

硬件的区别方法是: 引使用类型存在堆区,基本类型存储于栈中。

软件的区别方法是: 引使用类型的原型包含Object的实例, 而基本类型原型不包含Object的实例。

《野生前台工程师》所有文章均由@拭目以待原创,转载请联络作者。我的表格管理插件:gridmanager.lovejavascript.com。欢迎关注我的头条号-野生前台工程师

  • 全部评论(0)
最新发布的资讯信息
【系统环境|】你是HTML 5的一员吗?(2019-08-15 11:58)
【系统环境|】Web前端基础怎么学?html、css、JavaScript 知识架构图(2019-08-14 17:55)
【系统环境|】零基础小白走Web前端之路是否可行?答案是yes!(2019-08-13 11:44)
【系统环境|】你知道Web前端与HTML5技术的区别吗?(2019-08-12 14:10)
【系统环境|】移动前端开发和web前端开发的区别(2019-08-11 16:49)
【系统环境|】给新手的锦囊:Web前端开发小白的学习建议和路线图(2019-08-10 16:34)
【系统环境|】都说web前端开发薪资高,入行就有上万月薪,转行难吗?(2019-08-09 14:55)
【系统环境|】干货教程 | Web前端开发学习入门指南(2019-08-08 18:27)
【系统环境|】前端开发:vue路由之前端路由的原理(2019-08-07 13:17)
【系统环境|】你不知道的web前端那些事(2019-08-06 12:29)
手机二维码手机访问领取大礼包
返回顶部