这是一个AngularJS问题;我有一个简单的表格:
<input type="text" class="form-control" id="qus" placeholder="Enter Question" ng-model="qus">
<input type="text" class="form-control" id="op1" placeholder="Option 1" ng-model="op1">
<label><input type="checkbox" ng-model="correct1">Correct</label>
<button class="form-control btn btn-primary" ng-click = "save()">Save</button>
<pre ng-bind="dataShow"></pre>
脚本:
var app = angular.module('qApp', []);
app.controller('qCtrl', function($scope) {
var set = [];
var op1 = [];
$scope.save = function (){
if($scope.correct1!==true){$scope.correct1=false;}
op1.push($scope.op1, $scope.correct1);
var qus = [$scope.qus, op1];
set.push(qus);
$scope.dataShow = JSON.stringify(set);
};
});
输出:
在第一个条目中使用JSON.stringify
后,输出如下所示:
[
["q1",["o1",false]]
]
,第二个条目的输出是:
[
["q1", ["o1",false,"o2",true]],
["q2", ["o1",false,"o2",true]]
]
但我想要这样的事情:
[
["q1", ["o1",false,]],
["q2", ["o2",true]]
]
怎么做? true
/ false
是复选框的值。
答案 0 :(得分:2)
@Nagesh Sanika是对的。每个问题都有一个选项列表。因此,当向集合中添加新问题时,您可以每次创建选项数组。
var app = angular.module('qApp', []);
app.controller('qCtrl', function($scope) {
var set = [];
$scope.save = function (){
var op1 = []; // Moved it inside the save method
if($scope.correct1!==true){$scope.correct1=false;}
op1.push($scope.op1, $scope.correct1);
var qus = [$scope.qus, op1];
set.push(qus);
$scope.dataShow = JSON.stringify(set);
};
});
这是plunker。
答案 1 :(得分:1)
要获得结果,每次都需要清空op1数组。
var app = angular.module('qApp', []);
app.controller('qCtrl', function($scope) {
var set = [];
var op1 = [];
$scope.save = function (){
if($scope.correct1!==true){
$scope.correct1=false;
}
op1.push($scope.op1, $scope.correct1);
var qus = [$scope.qus, op1];
set.push(qus);
op1=[];
$scope.dataShow = JSON.stringify(set);
};
});
希望这有效:)