javascript - 关于JS的函数深拷贝问题?
ringa_lee
ringa_lee 2017-04-10 17:59:19
[JavaScript讨论组]
<script type="text/javascript">
            var obj={
                a:{
                    b:10
                }
            }
            function copy(obj){
                if(typeof obj !=="object"){
                    return obj;
                }
                var newobj={};
                for(var attr in obj){
                    newobj[attr]=copy(obj[attr]);
                }
                return newobj;
            }
            var obj2=copy(obj);
            obj2.a.b=40;
            alert(obj.a.b);
        </script>

关于这个函数在递归调用之后,怎么具体运行的。。

ringa_lee
ringa_lee

ringa_lee

全部回复(2)
阿神

啊咧,发现答非所问了...囧

你这里只是针对 Object 进行深拷贝(并没有考虑 function 和 Array),并且将原型链上的属性也拷贝到新实例上...(看起来有点儿奇怪...)

JavaScript 深拷贝我感觉是个大坑...

  • 首先你要明确需要深拷贝哪些数据类型:比如你这段代码对于 Array 没有进行判断。

  • 接着是递归的问题,如果循环引用了咋办?

  • 还有要不要拷贝 prototype 上的属性? 比如这里就没有用 hasOwnProperty 限制。这样会一直从原型链向上查找...

  • 最后还有 function,这个我觉得看需求,如果要在内存里保存两份儿方法,最好通过构造函数来生成实例。那么问题又来了,传哪些参数?╮(╯▽╰)╭

高洛峰

只要这个属性是引用类型,那么就继续调用copy函数,对这个引用类型属性进行处理,就这样一直下去,知道这个属性不是引用类型的,然后逐个出函数栈,这样你得到的就是一个深拷贝后的对象。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号