$scope.$watch('selectedPoll', function(newValue, oldValue){
if(newValue !== oldValue) {
$scope.arrayResult.q1 = [];
$scope.arrayResult.q2 = [];
$scope.arrayResult.q3 = [];
angular.forEach($scope.selectedPoll.questions, function(value, key) {
if (key) {
$scope.arrayResult = [];
var newArrayYes = [];
var newArrayNo = [];
for (var i = 0; i < $scope.selectedPoll.survey_data.length; i++) {
if ($scope.selectedPoll.survey_data[i][key] === "YES") {
var resultOfqYes = newArrayYes.push($scope.selectedPoll.survey_data[i]);
}
if ($scope.selectedPoll.survey_data[i][key] === "NO") {
var resultOfqNo = newArrayNo.push($scope.selectedPoll.survey_data[i]);
}
}
$scope.arrayResult.push({
value: resultOfqYes, color: "#46BFBD", highlight: "#5AD3D1",
label: "Yes"
});
$scope.arrayResult.push({
value: resultOfqNo, color: "#F7464A", highlight: "#FF5A5E",
label: "No"
});
$scope.arrayResult[key] = $scope.arrayResult;
return $scope.arrayResult[key];
}
});
}
});
});
我尝试获取三个数据集arrayResult.q1 q2和q3,一个用于selectedPoll.questions中的每个对象,但我只获得第三个,但是当我在if语句的末尾推出console.log时,我看到了对于angular.forEach方法的每个对象,都有单独的console.log。
我的问题,如果对每个对象执行“if”语句(在我的情况下是三次),我通过console.log验证了什么,为什么angular.forEach方法只返回selectedPoll.questions中最后一个对象的一个数据?
那么我应该在哪里修复它以获得三个数据集,每个对象由angular.forEach方法执行一个?
答案 0 :(得分:1)
您正在设置$ scope.arrayResult = [];在每个循环开始时覆盖在先前循环中设置的任何内容。