js数据类型的基础知识

1、基本数据类型(值类型)

number、string、boolean、null、undefined

2、引用数据类型

object 例如: {}、[]、/^$/、日期对象、Math 实例对象等...

function

3、ES6中新增

symbol 唯一值

 

检测数据类型 typeof

typeof NaN  => "number" 不是一个有效的数字,但是属于number数字类型

NAN 和谁都不相等 NAN == NAN => false 所以检测是否有效数字需要用 isNaN(把其他数据类型转换为number类型是一个有效数字返回false)

 

null与undefined的区别:

1、定义

(1)undefined:是所有没有赋值变量的默认值,自动赋值

(2)null:主动释放一个变量引用的对象,表示一个变量不再指向任何对象地址

2、何时使用null?

当使用完一个比较大的对象时,需要对其进行释放内存时,设置为null

 

3、null与undefined的异同点是什么呢?

共同点:都是原始类型,保存在栈中变量本地

不同点:

(1)undefined——表示变量声明过但并未赋过值。

它是所有未赋值变量默认值。

例如:var a; //a自动被赋值为undefined

(2)null——表示一个变量将来可能指向一个对象。

一般用于主动释放指向对象的引用。

例如:var emps = ['ss','nn'];

emps = null; //释放指向数组的引用

 

4、延伸——垃圾回收站

它是专门释放对象内存的一个程序。

(1)在底层,后台伴随当前程序同时运行;引擎会定时自动调用垃圾回收期;

(2)总有一个对象不再被任何变量引用时,才释放。

 

object 对象的属性名一定不能是应用数据类型,默认会把引用数据类型转换为字符串进行处理

例如:   

let a = {x:1}; 

let b = {y:2};

let obj = {};

obj[a] = '我是测试数据1';

obj[b] = '我是测试数据2';

console.log(obj[a] , obj[a] )  => 我是测试数据2',  我是测试数据2'

因为a,b 对象为 key 时会被转成字符串,相当于执行a.toString() =>"[object object]",此时obj[a]其实就是obj["[object object]"].

symbol 唯一值

例:

let a = {};

let b = Symbol();

let c = Symbol();

a[b] = '测试数据1';

a[c] = '测试数据2';

console.log(a[b], a[c]) // 测试数据1 测试数据2

a => {Symbol(): '测试数据1', Symbol(): '测试数据2'}

posted @ 2022-02-17 15:41  ZJ_自其  阅读(56)  评论(0)    收藏  举报