我有这样的html元素:
<body ng-controller="addController">
<div class="col-sm-10">
<label class="control-label">tableName:</label>
<fieldset ng-repeat="tableName in tableNames">
<input type="text" class="form-control" ng-model="tableName.tableName" /><br />
</fieldset>
<button class="btn btn-default" ng-click="addNewTable()">Add tablename</button>
<input type="submit" ng-click="add()" />
</div>
<div>
<pre>{{tableNames|json}}</pre>
</div>
</body>
此代码每次单击按钮时都会生成一个文本框。
JS:
function addController($scope, $http) {
$scope.tableNames = [];
$scope.addNewTable = function (tableName) {
$scope.tableNames.push({});
}
}
当我显示tableNames时,它给了我:
[{"tableName":"textboxvalue"},{"tableName":"textboxvalue"}];
但我打算获得输出:
[{"tableName1":"textboxvalue","tableName2":"textboxvalue","tableName3":"textboxvalue"}];
我需要更改设计才能获得所需的输出。 提前谢谢。
答案 0 :(得分:0)
您每次都将对象推送到数组,但您想要的是在数组中的对象中添加键值对。 试试这个
$scope.tableNames = [{}];
$scope.addNewTable = function (tableName) {
$scope.tableNames[0].tableName = "textboxvalue" ;
}