浅谈angular.copy() 深拷贝


Posted in Javascript onSeptember 14, 2017

因为项目中需要拷贝,查阅angularjs API文档,发现对angular.copy() 的解释:

复制一个对象或者一个数组(好吧,万物皆对象,数组也是一个对象)。

1> 如果省略了destination,一个新的对象或数组将会被创建出来;
2> 如果提供了destination,则source对象中的所有元素和属性都会被复制到destination中;
3> 如果source不是对象或数组(例如是null或undefined), 则返回source;
4> 如果source和destination类型不一致,则会抛出异常。 注意:这个是单纯复制覆盖,不是类似继承。

使用方法:

angular.copy(source, [destination]);

参数:

参数名称 参数类型 描述
source * 被copy的对象. 可以使任意类型, 包括null和undefined.
destination (optional) Object,array copy去的目的地. 可以省略, 如果不省略, 其必须和source是同类

返回值:

返回复制或更新后的对象

<!DOCTYPE html>
<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script src="http://apps.bdimg.com/libs/angular.js/1.2.16/angular.min.js"></script>
  </head>

  <body ng-app="copyApp">
    <div ng-controller="CopyController">
      <form novalidate class="simple-form">
        姓名: <input type="text" ng-model="user.name" /><br /> 
        年龄:<input type="number" ng-model="user.age" /><br /> 
        邮箱: <input type="email" ng-model="user.email" /><br />
        性别:<input type="radio" ng-model="user.gender" value="male" /> 男
        <input type="radio" ng-model="user.gender" value="female" /> 女
        <br />
        <button ng-click="reset()">重置</button>
        <button ng-click="update(user)">保存(拷贝)</button>
      </form>
      <pre>form = {{user | json}}</pre>
      <pre>master = {{master | json}}</pre>
    </div>

    <script>
      angular.module('copyApp', [])
        .controller('CopyController', ['$scope', function($scope) {
          $scope.master = {};
          $scope.update = function(user) {
            $scope.master = angular.copy(user);
            console.log($scope.master);
          };
          $scope.reset = function() {
            angular.copy($scope.user, $scope.master);
            console.log($scope.master);// Object { }
            console.log($scope.user); //undefined
          };
          $scope.reset();
        }]);
    </script>
  </body>

</html>

效果图

浅谈angular.copy() 深拷贝

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript Prototype 对象扩展
May 15 Javascript
ExtJS Ext.MessageBox.alert()弹出对话框详解
Apr 02 Javascript
javascript数组去重方法汇总
Apr 23 Javascript
Underscore源码分析
Dec 30 Javascript
详解JavaScript中数组和字符串的lastIndexOf()方法使用
Mar 13 Javascript
微信小程序-小说阅读小程序实例(demo)
Jan 12 Javascript
深入理解AngularJs-scope的脏检查(一)
Jun 19 Javascript
微信小程序获取微信运动步数的实例代码
Jul 20 Javascript
Vue常用指令详解分析
Aug 19 Javascript
vue中组件的过渡动画及实现代码
Nov 21 Javascript
JavaScript数组特性与实践应用深入详解
Dec 30 Javascript
JS立即执行的匿名函数用法分析
Nov 04 Javascript
说说AngularJS中的$parse和$eval的用法
Sep 14 #Javascript
用JS编写一个函数,返回数组中重复出现过的元素(实例)
Sep 14 #Javascript
日期时间范围选择插件:daterangepicker使用总结(必看篇)
Sep 14 #Javascript
详解React Native顶|底部导航使用小技巧
Sep 14 #Javascript
Angularjs 1.3 中的$parse实例代码
Sep 14 #Javascript
浅谈JavaScript中的属性:如何遍历属性
Sep 14 #Javascript
基于node.js express mvc轻量级框架实践
Sep 14 #Javascript
You might like
一个简单php扩展介绍与开发教程
2010/08/19 PHP
php写入、删除与复制文件的方法
2015/06/20 PHP
繁简字转换功能
2006/07/19 Javascript
js 获取子节点函数 (兼容FF与IE)
2010/04/18 Javascript
兼容IE和FF的js脚本代码小结(比较常用)
2010/12/06 Javascript
javascript实现des解密加密全过程
2014/04/03 Javascript
js 模式窗口(模式对话框和非模式对话框)的使用介绍
2014/07/17 Javascript
jQuery .tmpl() 用法示例介绍
2014/08/21 Javascript
Javascript学习笔记之相等符号与严格相等符号
2014/11/23 Javascript
轮播图组件js代码
2016/08/08 Javascript
BootStrap表单验证实例代码
2017/01/13 Javascript
基于Bootstrap 3 JQuery及RegExp的表单验证功能
2017/02/16 Javascript
基于VUE选择上传图片并页面显示(图片可删除)
2017/05/25 Javascript
bootstrap多层模态框滚动条消失的问题
2017/07/21 Javascript
node.js操作MongoDB的实例详解
2017/10/11 Javascript
Vue.js 使用v-cloak后仍显示变量的解决方法
2018/11/19 Javascript
vue的keep-alive中使用EventBus的方法
2019/04/23 Javascript
OpenLayer学习之自定义测量控件
2020/09/28 Javascript
react ant Design手动设置表单的值操作
2020/10/31 Javascript
python实现带验证码网站的自动登陆实现代码
2015/01/12 Python
Python中exit、return、sys.exit()等使用实例和区别
2015/05/28 Python
利用Python画ROC曲线和AUC值计算
2016/09/19 Python
Python xlwt设置excel单元格字体及格式
2020/04/18 Python
python实现定时自动备份文件到其他主机的实例代码
2018/02/23 Python
Python3利用print输出带颜色的彩色字体示例代码
2019/04/08 Python
python循环定时中断执行某一段程序的实例
2019/06/29 Python
Pytorch实现GoogLeNet的方法
2019/08/18 Python
python实现机器人卡牌
2019/10/06 Python
python编写俄罗斯方块
2020/03/13 Python
html5构建触屏网站之touch事件介绍
2013/01/07 HTML / CSS
Diamondback自行车:拥有你的冒险
2019/04/22 全球购物
What is EJB
2016/07/22 面试题
环保建议书500字
2014/05/14 职场文书
2019最新校园运动会广播稿!
2019/06/28 职场文书
Centos7中MySQL数据库使用mysqldump进行每日自动备份的编写
2021/08/02 MySQL
mysql的单列多值存储实例详解
2022/04/05 MySQL