angular.copy 详解

angular.copy

简介

  • 创建一个源文件的深度拷贝,它应该是一个对象或一个数组。
  • 如果没有提供目标,则创建一个对象或数组的副本。
  • 如果提供了一个目标,那么它的所有元素(对于数组)或属性(对于对象)都会被删除,然后从源文件中复制所有元素/属性。
  • 如果源不是对象或数组(包括nullundefined),则返回源。
  • 如果源与目标相同,则会抛出异常。

用法

  • angular.copy(source, [destination]);
    

参数

  • 参数类型说明
    source*将用于复制的源。可以是任何类型,包括原始类型、nullundefined
    destination(可选)Object Array源被复制的目标。如果提供,必须与源类型相同。

返回值

  • 如果指定了目标,则返回复制或更新的目标。

举个栗子

  • HTML:

  • <div ng-controller="ExampleController">
        <form novalidate class="simple-form">
            <label>Name: <input type="text" ng-model="user.name" /></label><br />
            <label>Age:  <input type="number" ng-model="user.age" /></label><br />
            Gender: <label><input type="radio" ng-model="user.gender" value="male" />male</label>
            <label><input type="radio" ng-model="user.gender" value="female" />female</label><br />
            <button ng-click="reset()">RESET</button>
            <button ng-click="update(user)">SAVE</button>
        </form>
        <pre>form = {{user | json}}</pre>
        <pre>master = {{master | json}}</pre>
    </div>
    
  • JS:

  • angular.
    module('copyExample', []).
    controller('ExampleController', ['$scope', function($scope) {
        $scope.master = {};
    
        $scope.reset = function() {
            // Example with 1 argument
            $scope.user = angular.copy($scope.master);
        };
    
        $scope.update = function(user) {
            // Example with 2 arguments
            angular.copy(user, $scope.master);
        };
    
        $scope.reset();
    }]);
    
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT枫斗者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值