Javascript浅拷贝与深拷贝实现

本文介绍JavaScript中的对象赋值原理及如何通过浅复制和深复制实现对象的克隆,避免对象间互相影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

导读:

Javascript中的对像赋值与Java中是一样的,都为引用传递.就是说,在把一个对像赋值给一个变量时,那么这个变量所指向的仍就是原来对像的地址.那怎么来做呢 答案是克隆.

什么是"clone"?

在实际编程过程中,我们常常要遇到这种情况:有一个对象A,在某一时刻A中已经包含了一些有效值,此时可能会需要一个和A完全相同新对象B,并且此后对B任何改动都不会影响到A中的值,也就是说,A与B是两个独立的对象,但B的初始值是由A对象确定的。在Java/javasript语言中,用简单的赋值语句是不能满足这种需求的。要满足这种需求虽然有很多途径,但实现clone()方法是其中最简单,也是最高效的手段,当然了 javascript语言中并没有此方法.

所以我特意写了两个克隆方法:一个为浅复制 ,一个为深复制.

解释:

浅复制(影子克隆):只复制对象的基本类型,对象类型,仍属于原来的引用.

深复制(深度克隆):不紧复制对象的基本类,同时也复制原对象中的对象.就是说完全是新对象产生的.

下面是测试代码:

运行代码框

< HTML>< HEAD>< TITLE> New Document < meta http-equiv="Content-Type" content="text/html; charset=gb2312">< META NAME="Generator" CONTENT="Wawa Editor 1.0">< META NAME="Author" CONTENT="八神奄">< META NAME="Keywords" CONTENT="Javascript,Java,XML,XSLT,ASP,VBScript,ASP .net,C#,C++,Database">< META NAME="Description" CONTENT="不及格的程序员,无所不在">< BODY>< SCRIPT LANGUAGE="JavaScript">

[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

欢迎大家到我们论坛中讨论!



本文转自

http://www.blueidea.com/tech/web/2003/1253.asp
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值