基本数据类型一般都是存在栈里
引用数据类型是存在堆里面的
let obj = {
name:"张麻子"
}
let obj1 = Object.assign({},obj,{age:20});
let obj1 ={...obj} //扩展运算符用法
obj1.name = "刘傻子"
console.log(obj)
//assign 合并对象的意思,可以合并多个对象,跟扩展运算符差不多
//assign(最少接受两个参数)
递归函数
let num = 10;
for( let i =0;i<num;i++){
console.log(i)
}
//简单的说,函数自己掉自己 就是是递归函数
function fn () { //注意我们在使用递归的时候,一定不能写成死循环(我们一般用return打断循环)
//fn() 不能在这里调用
console.log('我被执行了')
}
fn()//fn()在哪里都能调用
怎么使用 递归实现一个深拷贝呢
let obj = {
name: '张三',
msg:{
ext: '今年18了'
}
}
function copy(obj) { // obj 传入的对象就是你要拷贝的对象
let newObj = null; // 声明一个对象来存储拷贝之后的内容
// 判断数据类型是否是复杂的数据类型,如果是则调用自己,如果不是则直接赋值即可!
// 由于null不可以循环但是他的类型又是object,所以这个需要对null进行判断
// typeof 判断数据类型 object , array ,null 返回的值都是 'object'
// debugger
if (typeof(obj) == 'object' && obj !== null){
// 声明一个变量用以存储拷贝出来的值,根据参数的具体数据类型声明不同的类型来存储
newObj = obj instanceof Array? [] : {};
// 循环obj的每一项,如果里面还有复杂的数据类型的话,则直接利用递归函数再次调用。
for(let i in obj){ // i 这里的 i 有可能是 属性名 或者 索引
newObj[i] = copy(obj[i])
}
} else {
newObj = obj
}
return newObj; // 函数没有返回的值的话,则为undefined
}
let obj1 = copy(obj);
obj1.msg.ext = '我今年20了';