JavaScript中浅克隆和深度克隆有什么区别及具体应用场景?

2026-04-05 10:569阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计649个文字,预计阅读时间需要3分钟。

JavaScript中浅克隆和深度克隆有什么区别及具体应用场景?

本文简要介绍了JavaScript浅拷贝与深拷贝的对比及实例解析,内容简洁,适合初学者或工作人士快速了解,参考价值高。需要的朋友可参考下文:

一、浅拷贝与深拷贝对比浅拷贝:只复制对象的第一层属性,内部对象属性仍指向原对象。深拷贝:完全复制对象的所有属性,包括内部对象。

二、实例解析以下是一个浅拷贝与深拷贝的示例代码:

javascript// 浅拷贝function shallowCopy(obj) { var copy={}; for (var key in obj) { copy[key]=obj[key]; } return copy;}

// 深拷贝function deepCopy(obj) { var copy; if (obj instanceof Array) { copy=[]; for (var i=0, len=obj.length; i

// 示例对象var obj={ a: 1, b: [2, 3], c: { d: 4 }};

// 浅拷贝结果var shallowObj=shallowCopy(obj);console.log(shallowObj); // {a: 1, b: [2, 3], c: {d: 4}}

// 深拷贝结果var deepObj=deepCopy(obj);console.log(deepObj); // {a: 1, b: [2, 3], c: {d: 4}}

通过以上示例,可以看出浅拷贝和深拷贝的区别。在实际开发中,根据需求选择合适的拷贝方式,以提高代码的效率和稳定性。

JavaScript中浅克隆和深度克隆有什么区别及具体应用场景?

这篇文章主要介绍了javascript浅层克隆、深度克隆对比及实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

1、浅层克隆, (引用值改变, 两个都一起变)

var obj = { name : 'xiaoming', age : 12, children : ['mimi','lili','rokey'] } var obj2 = {}; function clone(origin, target) { var target = target || {}; for(var prop in origin) { target[prop] = origin[prop]; } return target; } clone(obj, obj2);

2、深度克隆 (只考虑数组和对象)

(1)判断是不是原始值

 (2)判断是数组还是对象 Object.prototype.toString.call([]) = '[object Array]' Object.prototype.toString.call({}) = '[object Object]'

(3)建立相应的数组和对象

(4)递归

function deepClone(origin, target) { var target = target || {}, toStr = Object.prototype.toString, arrStr = '[object Array]'; for(var prop in origin) { if(origin.hasOwnProperty(prop)) { //判断是不是对象自带的属性 if(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; }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计649个文字,预计阅读时间需要3分钟。

JavaScript中浅克隆和深度克隆有什么区别及具体应用场景?

本文简要介绍了JavaScript浅拷贝与深拷贝的对比及实例解析,内容简洁,适合初学者或工作人士快速了解,参考价值高。需要的朋友可参考下文:

一、浅拷贝与深拷贝对比浅拷贝:只复制对象的第一层属性,内部对象属性仍指向原对象。深拷贝:完全复制对象的所有属性,包括内部对象。

二、实例解析以下是一个浅拷贝与深拷贝的示例代码:

javascript// 浅拷贝function shallowCopy(obj) { var copy={}; for (var key in obj) { copy[key]=obj[key]; } return copy;}

// 深拷贝function deepCopy(obj) { var copy; if (obj instanceof Array) { copy=[]; for (var i=0, len=obj.length; i

// 示例对象var obj={ a: 1, b: [2, 3], c: { d: 4 }};

// 浅拷贝结果var shallowObj=shallowCopy(obj);console.log(shallowObj); // {a: 1, b: [2, 3], c: {d: 4}}

// 深拷贝结果var deepObj=deepCopy(obj);console.log(deepObj); // {a: 1, b: [2, 3], c: {d: 4}}

通过以上示例,可以看出浅拷贝和深拷贝的区别。在实际开发中,根据需求选择合适的拷贝方式,以提高代码的效率和稳定性。

JavaScript中浅克隆和深度克隆有什么区别及具体应用场景?

这篇文章主要介绍了javascript浅层克隆、深度克隆对比及实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

1、浅层克隆, (引用值改变, 两个都一起变)

var obj = { name : 'xiaoming', age : 12, children : ['mimi','lili','rokey'] } var obj2 = {}; function clone(origin, target) { var target = target || {}; for(var prop in origin) { target[prop] = origin[prop]; } return target; } clone(obj, obj2);

2、深度克隆 (只考虑数组和对象)

(1)判断是不是原始值

 (2)判断是数组还是对象 Object.prototype.toString.call([]) = '[object Array]' Object.prototype.toString.call({}) = '[object Object]'

(3)建立相应的数组和对象

(4)递归

function deepClone(origin, target) { var target = target || {}, toStr = Object.prototype.toString, arrStr = '[object Array]'; for(var prop in origin) { if(origin.hasOwnProperty(prop)) { //判断是不是对象自带的属性 if(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; }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。