`
lyyu1988
  • 浏览: 6432 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

JS完美实现对象克隆 (转)

阅读更多
我们知道,在js中,当object作为参数传递到函数中进行处理后,实际上是修改了传入的对象本身(或者说是对象的引用),但很多时候我们并不希望函数去修改我们的这些对象参数,这就需要使用到对象的克隆,我们应该对该对象做一个克隆,然后操作这个克隆的对象,这样就不会影响我们的原对象了。
    不过在js中并没有对象克隆功能,因此需要我们自己实现,实现方法也不复杂其实,基本上是做一些属性复制,我在网上找了一些,但有些实现并不好,如对于array对象克隆后就成json对象了,并没有保留原来的数组方式。不过最后还是找到了一个很好的克隆函数,完美实现了js对象的克隆功能,不论是Array对象或者是普通的Object,都可以很好的进行克隆,这个函数使用constructor(函数构造器)进行复制。

具体代码如下:

Object.prototype.Clone = function(){
    var objClone;
    if (this.constructor == Object){
        objClone = new this.constructor(); 
    }else{
        objClone = new this.constructor(this.valueOf()); 
    }
    for(var key in this){
        if ( objClone[key] != this[key] ){ 
            if ( typeof(this[key]) == 'object' ){ 
                objClone[key] = this[key].Clone();
            }else{
                objClone[key] = this[key];
            }
        }
    }
    objClone.toString = this.toString;
    objClone.valueOf = this.valueOf;
    return objClone; 
} 




function clone(myObj){
  if(typeof(myObj) != 'object') return myObj;
  if(myObj == null) return myObj;
  
  var myNewObj = new Object();
  
  for(var i in myObj)
    myNewObj[i] = clone(myObj[i]);
  
  return myNewObj;
}
分享到:
评论
1 楼 greatghoul 2011-06-10  
楼主好文,顶!

相关推荐

    html2canvas.js

    由于浏览器的安全策略,JavaScript无法直接访问像素级别的DOM节点,html2canvas.js通过一系列复杂的计算和模拟,实现了在浏览器内模拟绘制HTML元素的效果。 使用html2canvas.js时,我们首先要引入该库的文件,例如...

    vJavascript-clone:香草Javascript研究

    在"vJavascript-clone"项目中,我们可以推测其主要研究了如何使用JavaScript来实现对象的深度克隆。在JavaScript中,对象是引用类型,当进行赋值操作时,实际上是复制了对象的引用而不是对象本身。这可能导致意外的...

    完美编程

    《完美编程》这一主题涵盖了广泛而深入的编程知识,旨在帮助程序员实现代码的高效、优雅与可维护性。在这个领域,我们关注的核心是编写出既功能完备又具有良好设计的程序。下面将详细介绍其中的一些关键知识点。 1....

    JavaScript语言概述

    同年,Microsoft为了追赶Netscape的脚步,在其Internet Explorer 3.0中引入了名为JScript的JavaScript克隆版本。这些早期版本的JavaScript极大地提高了Web页面的响应性和功能性。 随着JavaScript的普及,为了确保...

    angry-birds:愤怒的小鸟克隆

    《愤怒的小鸟克隆:JavaScript实现的休闲游戏解析》 愤怒的小鸟,这款风靡全球的休闲游戏,以其独特的物理引擎和可爱的角色设计赢得了无数玩家的喜爱。在编程领域,克隆经典游戏是一种常见的学习和实践方式,特别是...

    使用Vue全家桶+Node.js搭建的小型全栈项目.zip

    这个项目可能是一个简易的豆瓣电影(Douban Movie)克隆版,用于展示如何将前端与后端完美结合,实现数据的动态获取和交互。 首先,Vue.js是当前非常流行的渐进式JavaScript框架,它允许开发者创建用户界面并管理...

    js拖拽图片

    本项目“js拖拽图片”是一个使用纯JavaScript实现的简单示例,专为初学者设计,以帮助理解这一功能的工作原理。在火狐浏览器中,这个例子可以完美运行。 首先,我们要了解JavaScript拖拽的基本步骤: 1. **选择可...

    QxThree:用于qooxdoo应用程序的Three.js集成插件

    **QxThree: qooxdoo与Three.js的完美结合** **一、介绍** QxThree是一个创新的插件,旨在将流行的JavaScript三维图形库Three.js无缝集成到qooxdoo框架中。qooxdoo是一个强大的开源JavaScript应用开发框架,提供了...

    4b-neatClone

    5. **兼容性**:考虑到JavaScript运行在多种环境(浏览器、Node.js等),`4b-neatClone`可能已经处理了不同环境下的兼容性问题,确保在各种环境下都能正常工作。 【使用示例】 ```javascript // 引入4b-neatClone...

    Craxe:Haxe转换为Nim Transpiler

    例如,Haxe的类系统需要转换为Nim的面向对象模型,Haxe的宏系统可能需要映射到Nim的元编程机制。 **使用Craxe** 使用Craxe进行转换通常包括以下步骤: 1. 安装Haxe和Nim环境。 2. 获取并安装Craxe转换器,这可以...

    CamelCamel

    例如,它可能提供一个将JSON字符串反序列化为JavaScript对象的函数,或者将JavaScript对象序列化为JSON字符串的函数。这样的功能使得数据交换变得轻而易举,同时也降低了出错的可能性。 再者,对于数组操作,...

    方形游戏

    SkillCrucial React Redux样板快速开始使用以下命令克隆此仓库: $ git clone git@github....对象解构箭头函数等Babel支持旧版浏览器SASS / SCSS:让样式再次完美无泪React路由器热模块更换可实现舒适的开

    YGOProxyGenerator

    1. **熟悉JavaScript基础**:理解变量、函数、对象等基本概念,以及DOM操作方法,是使用和修改此工具的前提。 2. **学习相关库和框架**:可能涉及到的库如jQuery、Underscore.js等,可以帮助简化代码和提高效率。 ...

    minggeJS

    MingGeJS1.9.4.2016完美正式版 头 英文版。 PS 1.95版本 1:继续加强创建例程界面,添加更多类型数据替代。 2:添加prepend appendTo prependTo之前之后,完全和JQ一一模一样,并且而且带事件克隆效果,这些接口...

    nodeJS-API

    在这个项目中,我们关注的是使用TypeORM进行数据库操作,这是一个强大的对象关系映射(ORM)库,尤其适用于Node.js环境,并且与TypeScript完美集成。 TypeORM是一个强大的ORM框架,它可以将JavaScript对象映射到...

    much-programming-core:这样的核心,很多编程Vortex CORE的编程实用程序

    该工具可在离线状态下完美运行,因此您可以下载/克隆存储库并破解js文件,以查看如何处理固件。骇客目前,二进制生成代码是从MPC官方网站上获取的。 仍有优化空间,甚至可以使用自定义二进制格式启用更多功能。 您...

    0x40-web:漂亮的图像和色彩

    示例页面:您还可以制作与歌曲节奏完美同步的动画。 受到Kepstin积分实验的启发。 安装(制作自己的色相) 首先下载最新。 这些被最小化并且加载更快。 将您的重新打包zip放在您的Web服务器可以找到的位置。 我的...

    super-bass:开始用ES6编写React

    - **克隆仓库**:使用Git工具克隆`super-bass`仓库,这通常包含了一个React项目的基础结构。 - **进入目录**:在命令行中,使用`cd super-bass-master`进入项目根目录。 - **安装依赖**:运行`npm install`安装...

    w11-routes-2

    使用以下命令克隆此仓库: $ git clone git@github.com:ovasylenko/skillcrucial-react-redux-boilerplate.git 要安装依赖项并清理git repo运行: $ yarn install 我们建议使用yarn来安装软件包,但是您可以使用...

    my-project-manager:只是我很酷的项目经理

    使用以下命令克隆此仓库: $ git clone git@github.com:ovasylenko/skillcrucial-react-redux-boilerplate.git 要安装依赖项并清理git repo运行: $ yarn install 我们建议使用yarn来安装软件包,但是您可以使用...

Global site tag (gtag.js) - Google Analytics