gpt4 book ai didi

javascript - Angularjs:访问范围变量数组并计算平均值

转载 作者:行者123 更新时间:2023-11-28 01:43:14 25 4
gpt4 key购买 nike

很抱歉,如果问题与标题相比有点抽象。我将尝试在这里解释它并提供带有相关代码的要点。

我有一个 JSON api,我通过 AngularJS 获取它。这基本上是一个包含多个任务的项目。我想浏览 $scope.projects 变量(在我的项目 Controller 中)中的任务并获取每个任务中的所有“进度”值。然后我想计算它们的平均值以给出项目本身的总体进度并将其分配给要在我的模板中使用的 $scope 变量。

无论我尝试什么,我似乎都无法访问任务数组,而且我不知道为什么。所以我想在这里寻求一些建议可能是一个不错的选择。任何帮助将不胜感激。

要点:https://gist.github.com/Tasemu/8002741

JS

App.controller('ProjectCtrl', ['$scope', 'Project', 'Task', '$routeParams', '$location', function($scope, Project, Task, $routeParams, $location) {

$scope.updateProjects = function() {
if (!$routeParams.id) {
Project.query(function(data) {
$scope.projects = data;
});
} else {
$scope.projects = Project.get({id: $routeParams.id})
}
};

$scope.deleteProject = function(project) {
Project.delete({id: project.id}, function() {
$scope.updateProjects({id: project.id});
$location.path('/');
});
};

$scope.deleteTask = function(task) {
Task.delete({id: task.id}, function() {
$scope.updateProjects({id: task.id});
});
};

$scope.updateProject = function(formData) {
$scope.projects.name = formData.name;
$scope.projects.description = formData.description;
$scope.projects.client = formData.client;
$scope.projects.due = formData.due;
$scope.projects.$update({id: formData.id}, function() {
$location.path('/');
});
};

$scope.saveProject = function(project) {
Project.save({}, project, function() {
$location.path('/');
});
};

$scope.updateProjects();

$scope.progs = [];

for (var i = 0; i > $scope.projects.tasks.length; i++) {
progs.push($scope.projects.tasks.array[i].progress);
};

}]);

JSON

{
id: 1,
name: "Project 1",
description: "this project",
client: "monty",
due: "2013-12-15",
tasks: [
{
id: 2,
name: "Task 2",
progress: 22,
project_id: 1,
created_at: "2013-12-17T03:08:53.849Z",
updated_at: "2013-12-17T05:06:31.602Z"
},
{
id: 1,
name: "Task 1",
progress: 75,
project_id: 1,
created_at: "2013-12-17T03:08:53.845Z",
updated_at: "2013-12-17T05:25:50.405Z"
}
],
created_at: "2013-12-17T03:08:53.719Z",
updated_at: "2013-12-17T06:57:52.699Z"
}

JS

App.factory('Project', function($resource) {
return $resource(
'/api/v1/projects/:id.json',
{id: '@id'},
{
update: {
method: 'PUT',
params: { id: '@id' },
isArray: false
}
}
);
});

如果您需要更多信息,请随时询问!

最佳答案

您必须延迟进度计算(project_controller.js 中的第 46 行到 48 行),直到数据完全加载。将计算提取到一个新方法中,并在第 6 行的回调中调用这个新方法,并在第 9 行创建一个新的回调。

关于javascript - Angularjs:访问范围变量数组并计算平均值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20631321/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com