我有这个 JSFiddle 代码:
http://jsfiddle.net/rnnb32rm/285/
<div ng-app="angularjs-starter" ng-controller="MainCtrl">
<fieldset data-ng-repeat="choice in choicesA">
<input type="text" ng-model="choice.name" name="" placeholder="Enter name">
<button class="addfields" ng-click="addNewChoice()">Add fields</button>
<button class="remove" ng-click="removeChoice()">-</button>
</fieldset>
<div id="choicesDisplay">
{{ choicesA }} <br/>
{{ choicesB }}
</div>
</div>
JS:
var app = angular.module('angularjs-starter', []);
app.controller('MainCtrl', function($scope) {
$scope.choicesA = [{id: 'choice1'}, {id: 'choice2'}];
$scope.choicesB = [];
$scope.addNewChoice = function() {
var newItemNo = $scope.choicesA.length+1;
$scope.choicesA.push({'id':'choice'+newItemNo});
};
$scope.removeChoice = function() {
var lastItem = $scope.choicesA.length-1;
$scope.choicesA.splice(lastItem);
};
});
如您所见,我有一个addNewChoice()
将对象添加到数组的函数choicesA
,然后根据choicesA
数组上的对象编号添加文本框。
fieldset
只有当我单击第一个上的Add fields
按钮时,我才需要将文本框添加到第一个fieldset
,并且我在这些生成的文本框中写入的数据被绑定并添加到choicesB
数组中的单独对象中。对于所有其他Add fields
按钮也是如此(因此每个Add field
按钮只能将文本框添加到自己的fieldset
标签中),这也是根据choicesA
数组中对象的数量生成的。
我什么都试过了,就是想不通。如果有点不清楚,我可以解释更多。提前谢谢你。
编辑:谢谢大家的大力帮助,让我解释一下:
我有一个 Spring REST API 和两个Java
名为 Resource & Action 的对象(JPA 实体),对象 Resource 包含一个 Action 列表,Action 包含对 Resource 的引用。
Resource
当我加载一个页面时,我得到一个我已经保存的对象数组,通过一个 $http.get() 方法从数据库返回,命名为choicesA
,数组的结构是这样的:
[
{"idResource":1, "nameResource": "resName1"},
{"idResource":2, "nameResource": "resName2"}
......etc depends oh how much rows I got from the DB
]
我有另一种方法 $http.post() ,它发布一个Action
名为choicesB
单独非嵌套数组的对象数组。数组结构是这样的:
[
{"idAction":1, "nameAction":"nameAction1", "resource":
{"idResource":1, "nameResource": "resName1"},
{"idAction":2, "nameAction":"nameAction2", "resource":
{"idResource":2, "nameResource": "resName2"},
..
}
{...},
{...}
...
]
所以choicesA
数组包含了Resource
我用 $http.get() 得到的对象,然后我想Action
在数组中填充对象,choicesB
然后使用 $http.post() 保存数组,每个都Action
应该包含一个Resource
对象。例如,如果我单击以在第一个fieldset
标记中添加更多操作,则意味着我要填充数组中的第一个Action
对象,并将位于数组中choicesB
的第一个对象分配给它等等。Resource
choicesA
我希望能够决定动作的数量并填写它们,然后将它们保存到choicesB
数组中。Resource
但是每个动作都与我描述的特定对象相关。
我希望现在很清楚,对不起,再次感谢您。