angularjs创建动态表单元素

时间:2017-03-01 04:21:47

标签: javascript angularjs object

我有这样的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"}];

我需要更改设计才能获得所需的输出。 提前谢谢。

1 个答案:

答案 0 :(得分:0)

您每次都将对象推送到数组,但您想要的是在数组中的对象中添加键值对。 试试这个

 $scope.tableNames = [{}];
    $scope.addNewTable = function (tableName) {
        $scope.tableNames[0].tableName = "textboxvalue" ;

    }