文章目录
JavaScript有哪些数据类型?
JavaScript由七种内置对象,可以分为两大类
- 基本类型:null、undefined、boolean、number、string、Symbol
- 对象:对象还可以更加的细分
es6中新增了什么数据类型,说说特点,有什么作用?
es6中新增了Symbol,Symbol()可以接受一个字符串,对symbol的描述,可用于调试但不是访问symbol本身,即使每次Symbol的描述相同,他们存放在不同的内存。(无法被重建的基本类型)
Symbol的作用:1. 作为对象的属性,用作key 2. 解决命名冲突 3. 模拟私有属性
对象在内存中怎么存储的?
注意: 基本数据类型直接存在栈中
null和undefined的共同点和区别?
共同点:
- 他们都表示一个无效的值,都是基本数据类型,都没有相关的包装对象和方法
- undefined == null //true
- 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,会报错,如果是其他类型就继续检测右边调用的方法,如果找到了对应的方法就调用,如果没有就报错。
对包装对象增加一个方法会有什么样的结果?
因为所有的每个基本类型的包装对象是一样的,所以对某个包装对象增加一个方法,那么所有的基本对象都可以调用这个方法。不过不推荐在包装对象上直接添加方法/属性。