![](/img/trans.png)
[英]I want to have a javascript function run only after HTML5 form input has been validated
[英]How can I run a javascript function only after a $http request has been made in Angular?
我正在使用Angular.js应用程序,该应用程序对GitHub API进行了一些调用。 首先,进行调用以检索用户的所有存储库。 然后,对于每个存储库,都会调用以检索自述文件。 我有一个javascript函数,只有在所有README API调用完成后才能运行。
这是我的控制器:
readmeSearch.controller('ReadMeSearchController', ['RepoSearch', 'ReadMeSearch', function(RepoSearch, ReadMeSearch) {
var self = this;
self.gitRepoNames = [];
self.readMes = [];
self.noReadMes = [];
self.doSearch = function() {
RepoSearch.query(self.username)
.then(function(repoResponse) {
addRepoNames(repoResponse);
for(var i = 0; i< self.gitRepoNames.length; i++) {
(function(i) {
ReadMeSearch.query(self.username, self.gitRepoNames[i])
.then(function(readMeResponse) {
addToReposWithReadMes(readMeResponse, i);
}).catch(function(e){
addToReposWithoutReadMes(repoResponse, i);
});
})(i);
};
});
};
addRepoNames = function(response) {
self.searchResult = response.data;
for(var i = 0; i < self.searchResult.length; i++) {
var name = self.searchResult[i]['name']
self.gitRepoNames.push(name);
};
};
addToReposWithReadMes = function(response, i) {
self.readMes.push(
{
name: self.gitRepoNames[i],
size: parseInt(response.data["size"]),
url: response.data["html_url"]
}
);
};
addToReposWithoutReadMes = function(response, i) {
self.noReadMes.push(
{
name: self.gitRepoNames[i]
}
);
};
percentageOfReposWithReadMes = function() {
var percentage;
percentage = (self.noReadMes.length / self.gitRepoNames.length) * 100
self.readMePercentage = percentage.toFixed(1);
};
}]);
使用ReadMeSearch工厂的README API调用将填充两个数组,一个数组用于包含README的存储库,另一个数组用于不具有README的存储库。 我想运行的功能percentageOfReposWithReadMes
唯一的后ReadMeSearch.query
已经完成了所有回购self.gitRepoNames
。
我已经尝试使用.then
在后RepoSearch.query
但这似乎并没有工作。 我对Angular Promise和.then
函数的理解有些.then
。 任何帮助将不胜感激。
你可以尝试使用$q.all
,这将reslove承诺的数组, .then
所有这些完成之后,你可以运行你的函数。
我自己尝试尝试时遇到麻烦,如果您有笨拙的东西会更容易。
我确实找到了解释这一点的线程,也许您可以在那里找到答案。
我认为您必须创建两个延迟,然后在循环结束时解决。 随着$ q.all你可以等待,直到两个指完成并调用percentageOfReposWithReadMes
功能。
readmeSearch.controller('ReadMeSearchController', ['RepoSearch', 'ReadMeSearch', '$q', function(RepoSearch, ReadMeSearch, $q) {
var self = this;
var gitRepoNameDefer;
var noReadMesDefer;
self.gitRepoNames = [];
self.readMes = [];
self.noReadMes = [];
self.doSearch = function() {
RepoSearch.query(self.username)
.then(function(repoResponse) {
gitRepoNameDefer = $q.defer();
noReadMesDefer = $q.defer();
addRepoNames(repoResponse);
for(var i = 0; i< self.gitRepoNames.length; i++) {
(function(i) {
ReadMeSearch.query(self.username, self.gitRepoNames[i])
.then(function(readMeResponse) {
addToReposWithReadMes(readMeResponse, i);
}).catch(function(e){
addToReposWithoutReadMes(repoResponse, i);
}).finally(function () {
finishDefers(i, self.gitRepoNames.length - 1);
});
})(i);
}
$q.all([gitRepoNameDefer, noReadMesDefer ]).then(fucntion () {
percentageOfReposWithReadMes();
});
});
};
addRepoNames = function(response) {
self.searchResult = response.data;
for(var i = 0; i < self.searchResult.length; i++) {
var name = self.searchResult[i]['name']
self.gitRepoNames.push(name);
};
};
addToReposWithReadMes = function(response, i) {
self.readMes.push(
{
name: self.gitRepoNames[i],
size: parseInt(response.data["size"]),
url: response.data["html_url"]
}
);
};
addToReposWithoutReadMes = function(response, i) {
self.noReadMes.push(
{
name: self.gitRepoNames[i]
}
);
};
function finishDefers (index, limit) {
if (index === limit) {
gitRepoNameDefer.resolve(self.readMes);
noReadMesDefer.resolve(self.noReadMes);
}
}
function percentageOfReposWithReadMes () {
var percentage;
percentage = (self.noReadMes.length / self.gitRepoNames.length) * 100
self.readMePercentage = percentage.toFixed(1);
};
}]);
回到你的承诺,并从链这些承诺
self.doSearch = function() {
var namesPromise =
RepoSearch.query(self.username)
.then(function(repoResponse) {
addRepoNames(repoResponse);
//return promises for chaining
return lookupNamesPromises(repoResponse);
}) .catch (function (error) {
//log error
});
//chain from promise
namesPromise.then (function(promises) {
$q.all(promises).finally( function() {
percentageOfReposWithReadMes();
})
});
//return promise for chaining elsewhere
return namesPromise;
};
查找函数返回一个promise数组。
self.lookupNamesPromises = function (repoResponse) {
var namesPromises = [];
for(var i = 0; i< self.gitRepoNames.length; i++) {
//begin IIFE closure
(function(i) {
var p = (ReadMeSearch.query(self.username, self.gitRepoNames[i])
.then(function(readMeResponse) {
addToReposWithReadMes(readMeResponse, i);
return readMeResponse;
}).catch(function(e){
addToReposWithoutReadMes(e, i);
return e;
})
);
namesPromises.push(p);
})(i);
//end IIFE closure
}
//return promises for chaining
return namesPromises;
};
通过链接您的诺言,后续功能将等待之前的功能完成。 函数式编程的经验法则总是返回一些东西 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.