【发布时间】:2014-02-04 08:26:54
【问题描述】:
我想迭代位于 HTML 5 文件系统中的所有文件,并在迭代完成后启动一些事件。由于这是异步 + 承诺,我很难理解它应该如何工作。
我正在使用 angularJS 并创建了一个服务来封装 html 5 文件系统的特定功能。
这是递归函数:
function walkDirectory(path) {
fileSystem.getFolderContents(path) //this is the services and it returns a promise containing all files in the current folder or directory
.then(function(entries) {
for (var i = 0; i < entries.length; i++) {
if(entries[i].isFile) {
console.log("is File: " + entries[i].name);
//do something with file here
}
else if (entries[i].isDirectory) {
console.log("is Dir: " + entries[i].name);
walkDirectory(entries[i].fullPath);
}
}
});
};
理想情况下,我想像这样调用该函数,并让它返回一个承诺,一旦所有文件都被遍历,该承诺就会被执行。
walkDirectory("/").then( function() {
console.log(done);
});
任何提示/想法如何实现?
一个想法是有一个承诺数组,并为每个文件/目录的数组添加一个新的承诺。我的尝试:
function walkDirectory(path) {
var defer= $q.defer();
var promises = [defer.promise];
fileSystem.getFolderContents(path)
.then(function(entries) {
for (var i = 0; i < entries.length; i++) {
if(entries[i].isFile) {
console.log("is File: " + entries[i].name);
//do something with file here
defer.resolve();
promises.push(defer.promise);
}
else if (entries[i].isDirectory) {
console.log("is Dir: " + entries[i].name);
promises.push(walkDirectory(entries[i].fullPath));
}
}
});
return $q.all(promises);
};
walkDirectory("/").then(function() {
console.log("done");
});
这似乎不起作用,因为控制台中永远不会显示完成。
【问题讨论】:
-
也许看看this answer
-
遍历html5文件系统的完整函数:stackoverflow.com/a/44918780/2277240
标签: javascript angularjs asynchronous promise q