AngularJS json多维数组看起来不应该是

时间:2015-09-07 10:56:14

标签: javascript arrays json angularjs multidimensional-array

这是一个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是复选框的值。

2 个答案:

答案 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); 
 };
});

希望这有效:)