搜索
首页 电脑/网络

JS中浅度克隆和深度克隆有什么区别

全部回答

2023-03-24

0 0

    本文章分享的是JavaScript中一个重要的知识点克隆,具有一定的参考价值,希望对大家的学习有所帮助JavaScript中克隆分为两种:浅度克隆和深度克隆,都是先对值遍历一遍判断是原始值还是引用值,原始值直接复制,引用值先判断是对象还是数组再进行克隆原始值:像Undefined,Null,Boolean,Number和String值被称为原始值引用值:像对象数组函数等值称为引用值浅度克隆主要是将数据的地址赋给对应的变量但并没有将具体的值赋值给对应的变量,变量会随着数据的改变而改变<script> var obj={ name:"张三" age:18, sex:"male" grade:[' Math:90''English:88''Chinese:80'] } var obj1={} function clone(origin,target){ var target=target||{}; for(var prop in origin){ target[prop]=origin[prop]; }//防止用户不传target对象,给了参数就直接用,不给就当空对象, return target; } clone(obj,obj1); </script>结果obj1将obj的值克隆过来了,当给obj的grade添加值时,obj1的grade的值也随之改变了深度克隆是将数据赋值给相对应的变量,所以产生了一个新的数据也就有了新的地址,原数据的改变不会影响新数据<script type="text/javascript">var obj={ name:"张三" age:18, sex:"male" grade:[' Math:90''English:88''Chinese:80'] } var obj1={} function deepClone(origin,target){var target=target||{},toStr=Object。
    prototype。toString,//简化代码arrStr="[Object Array]"for(var prop in origin){//从原始 origin 拷贝到 target if(origin。
  hasOwnProperty(prop)){///先判断是不是原型上的属性,如果是false 就是原型上的 { if(typeof(origin[prop])!== "null" && typeof (origin[prop]) =='object') { if(toStr。
    call(origin[prop])==arrStr){ target[prop]=[]; }//数组对象 else{ target[prop]={}; }//对象// deepClone(origin[prop],target[prop]); } else{ target[prop]=origin[prop]; } } } return target; }</script>结果obj1将obj的值克隆过来了,当给obj的grade添加值时,obj1的grade的值不会改变。
    。

类似问题换一批

热点推荐

热度TOP

相关推荐
加载中...

热点搜索 换一换

电脑/网络
电脑/网络
程序设计
电脑装机
操作系统/系统故障
硬件
笔记本电脑
百度
互联网
反病毒
软件
举报
举报原因(必选):
取消确定举报