最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript基于遍历操作实现对象深拷贝功能示例

来源:动视网 责编:小采 时间:2020-11-27 22:00:31
文档

JavaScript基于遍历操作实现对象深拷贝功能示例

JavaScript基于遍历操作实现对象深拷贝功能示例:本文实例讲述了JavaScript基于遍历操作实现对象深拷贝功能。分享给大家供大家参考,具体如下: function getType(o){ var _t; return ((_t = typeof(o)) == object ? o==null && null Object.prototype
推荐度:
导读JavaScript基于遍历操作实现对象深拷贝功能示例:本文实例讲述了JavaScript基于遍历操作实现对象深拷贝功能。分享给大家供大家参考,具体如下: function getType(o){ var _t; return ((_t = typeof(o)) == object ? o==null && null Object.prototype

本文实例讲述了JavaScript基于遍历操作实现对象深拷贝功能。分享给大家供大家参考,具体如下:

function getType(o){
 var _t;
 return ((_t = typeof(o)) == "object" ? o==null && "null" || Object.prototype.toString.call(o).slice(8,-1):_t).toLowerCase();
}
function extend(destination,source){
 for(var p in source){
 if(getType(source[p])=="array"||getType(source[p])=="object"){
 destination[p]=getType(source[p])=="array"?[]:{};
 arguments.callee(destination[p],source[p]);
 }else{
 destination[p]=source[p];
 }
 }
}
var test={
 a:"ss",
 b:"dd",
 c:[
 {d:"css",e:"cdd"},
 {
 m:"ff",
 n:[
 {kk:"11",jj:"22"},
 {ll:"44"}
 ]
 }
 ]
};
var test1={};
extend(test1,test);
console.log(test);
console.log(test1);
test1.c[1].n[0].kk="change"; //改变test1的c属性对象的d属性
console.log(test);
console.log(test1);
console.log(test.c[1].n[0]);
console.log(test1.c[1].n[0]);

测试结果

从测试结果可以看到,通过使用这个遍历的方法,成功将对象test深拷贝复制一份,得到test1。并且更改test1对象的属性,并不会对test对象产生影响。

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

文档

JavaScript基于遍历操作实现对象深拷贝功能示例

JavaScript基于遍历操作实现对象深拷贝功能示例:本文实例讲述了JavaScript基于遍历操作实现对象深拷贝功能。分享给大家供大家参考,具体如下: function getType(o){ var _t; return ((_t = typeof(o)) == object ? o==null && null Object.prototype
推荐度:
标签: 实现 对象 实例
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top