angular.copy
简介
- 创建一个源文件的深度拷贝,它应该是一个对象或一个数组。
- 如果没有提供目标,则创建一个对象或数组的副本。
- 如果提供了一个目标,那么它的所有元素(对于数组)或属性(对于对象)都会被删除,然后从源文件中复制所有元素/属性。
- 如果源不是对象或数组(包括
null
和undefined
),则返回源。 - 如果源与目标相同,则会抛出异常。
用法
-
angular.copy(source, [destination]);
参数
-
参数 类型 说明 source * 将用于复制的源。可以是任何类型,包括原始类型、 null
和undefined
。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(); }]);