老🐎回头之变量类型

117 阅读1分钟

值类型和引用类型

// 值类型,
let a=100
let b=a
a=200
console.log(b) //100

//引用类型
let a = {age:20}
let b = a
b.age = 21
console.log(a.age) //21
  • 值类型直接拷贝栈中的数据
  • 引用类型是拷贝栈中存放的堆内存地址
  • typeof 判断所有值类型、可以识别函数、可以判断是否为引用类型(无法判断具体类型)
  • instanceof 判断数组对象,函数是一个特殊的可自执行的object
  • null用typeof判断是对象,只不过是空的
  • NaN只用能typeof进行判断,且结果为number

深拷贝(基础版)

function deepClone(obj){
    if(typeof obj!=='object'||obj == null){
        // 当obj是空,或者不是数组、对象,就直接返回
        return obj
    }
    //初始化返回结果
    let result
    if (obj instanceof Array) {
        result = []
    }else{
        result = {}
    }
    for(let key in obj){
         if (obj.hasOwnProperty(key)) {
             // 保证key不是原型的属性
             //递归调用
             result[key] = deepClone(obj[key])
             
         }
    }
    //返回结果
    return result
}

当然,也有ES6模块的解决方案

let copyObj = JSON.parse(JSON.stringify(obj));

这里值得一提的是 Object.assign({},obj)在obj只有一层的时候是深拷贝,多层的时候是浅拷贝,能浅拷贝方式还有如下几种:

  • Array.prototype.concat()
  • Array.prototype.slice()