JavaScript数据类型简要分析


JavaScript有哪些数据类型?

JavaScript由七种内置对象,可以分为两大类

  • 基本类型:null、undefined、boolean、number、string、Symbol
  • 对象:对象还可以更加的细分

es6中新增了什么数据类型,说说特点,有什么作用?

es6中新增了Symbol,Symbol()可以接受一个字符串,对symbol的描述,可用于调试但不是访问symbol本身,即使每次Symbol的描述相同,他们存放在不同的内存。(无法被重建的基本类型)
Symbol的作用:1. 作为对象的属性,用作key 2. 解决命名冲突 3. 模拟私有属性

对象在内存中怎么存储的?

对象在内存中的存储
注意: 基本数据类型直接存在栈中

null和undefined的共同点和区别?

共同点:

  1. 他们都表示一个无效的值,都是基本数据类型,都没有相关的包装对象和方法
  2. undefined == null //true
  3. Boolean(null) //false Boolean(undefined) //false

区别:

  • Number(null) //0
    Number(undefined) //NaN
  • null: 一个对象被认为的重置为空对象,而非一个变量最原始的状态,在内存中表示就是,栈中的变量没有指向堆中的内存对象;当一个对象被赋值了null,原来的对象在内存中就处于游离状态,GC会择机回收对象并释放内存。因此,如果需要释放某个对象,就将这个变量设置为null,即表示该对象已经被清空,目前无效状态
    undefined:
  • 声明了一个变量,但是没有赋值
  • 访问对象上不存在的属性
  • 函数定义了形参,但是没有传递实际参数
  • 使用void对表达式求值

那些情况会出现undefined?

  • 声明了一个变量,但是没有赋值
  • 访问对象上不存在的属性
  • 函数定义了形参,但是没有传递实际参数
  • 使用void对表达式求值

基本类型没有方法,为什么我们还是对基本类型使用.toString()、.valueOf()方法?

当一个基本数据类型使用点操作符去调用一个方法时,JavaScript编译器检测到点操作符的左边是一个基本数据类型,那么它就会将其专成对应的包装对象,如果时null、undefined,会报错,如果是其他类型就继续检测右边调用的方法,如果找到了对应的方法就调用,如果没有就报错。

对包装对象增加一个方法会有什么样的结果?

因为所有的每个基本类型的包装对象是一样的,所以对某个包装对象增加一个方法,那么所有的基本对象都可以调用这个方法。不过不推荐在包装对象上直接添加方法/属性。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值