JS 引用类型的赋值操作

简单数据类型/基本数据类型

    // 此时 str1 中存储的是 数据 北京
    var str1 = '北京';

    // 将 str1 中存储的数据北京 赋值给 str2 
    var str2 = str1;

    // 之后对str1 的操作,与str2,无关
    str1 = '上海';

    console.log(str1 , str2);//上海 北京

引用数据类型/复杂数据类型

    // arr1 变量中 存储的是 数组的 内存地址
    var arr1 = [1,2,3,4,5];

    // 将arr1 存储的内存地址,赋值给arr2,两个变量存储的是相同的内存地址
    var arr2 = arr1;

    // arr1操作,数组,arr2也会改变
    // 因为arr1和arr2,同时存储的是相同的数据,操作的也是同一个数组
    // 同理,arr2,操作数组,arr1也会改变
    arr1[0] = '北京';

    console.log(arr2);
  1. 直接将一个引用数据类型的地址,赋值给另一个变量存储的,称为浅拷贝;两个变量存储的是相同的内存地址,一个操作,另一个也会改变
    不想两个变量操作数组,都会改变,想建立一个独立的变量,只是存储相同的数据
    需要建立一个独立的变量,复制引用数据类型中的数据内容

  2. 只复制 引用数据类型中的 数值 而不是 复制地址,称为 深拷贝

     // 只复制arr3中的数据
     var arr3 = ['北京','上海','广州','重庆','天津'];
    
     // 循环遍历,获取arr3中的所有数据数值,赋值到新的数组中
     var arr4 = [];
    
     // 通过循环,生成arr3的所有索引下标
     for(var i = 0 ; i <= arr3.length-1 ; i++){
         // arr3[i] 就是获取 arr3中的 存储的 数据信息
         // arr4.push() 将arr3中的数据 arr3[i] , 写入到 arr4中
         arr4.push(arr3[i]);
     }
    
     console.log(arr4);
    
     arr3[0] = '武汉';
    
     console.log(arr3 , arr4);
    

总结

  1. 基本数据类型:
    赋值的是 存储的数据
    赋值之后 两个变量没有关系

  2. 引用数据类型:
    (1)浅拷贝
    直接赋值 赋值的是 内存地址
    赋值之后 两个变量使用的相同内容,一个操作,另一个也会改变
    (2)深拷贝
    循环遍历,获取引用数据类型中,存储的每一个数据信息
    赋值到新的变量中
    赋值之后 两个变量,没有任何关系

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值