- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法找出使用 promises 的最佳方式。我正在尝试创建一个例程来复制文件夹,并且我发现自己正在尝试按顺序处理 promise 。我编写的代码不太优雅:
copyFolder = function( source, target ) {
var deferred = $q.defer();
var sourceFolder = null;
var sourcePromise = Windows.Storage.KnownFolders.documentsLibrary.getFolderAsync(sourcePath)
sourcePromise.then(function(dir) {
sourceFolder = dir;
}, function(error) {
return
});
var targetFolder = null;
var targetPromise = Windows.Storage.KnownFolders.documentsLibrary.getFolderAsync(targetPath)
targetPromise.then(function(dir) {
targetFolder = dir;
}
$q.all( sourcePromise, targetPromise ).then( function() {
if ( !targetFolder ) {
var createPromise = Windows.Storage.KnownFolders.documentsLibrary.createFolderAsync(targetPath)
createPromise.then(function(dir) {
targetFolder = dir;
}
}
createPromise.then( function() {
deferred.resolve( copyFolderRecursively(sourceFolder, targetFolder) );
});
});
return deferred.promise;
}
请注意,我正在复制 Documents 文件夹中的文件,因此无法使用 cordova-plugin-file
。
对于targetFolder
,我检查它是否存在(targetPromise
)。如果没有,我会创建它 (createPromise
)。我喜欢 $q.all()
调用的想法,遗憾的是它不能用于 createPromise
。
最重要的是,我正在尝试创建一个递归函数,该函数将在复制所有文件后返回。实际上,如果它能够返回一个 Promise(或构建一个 Promise 列表),那就更好了。
这段代码可以写成更优雅的形式吗?另外,是否有一个我可以遵循的实现 promise 的递归函数的示例?
最佳答案
我意识到我可以创建一个依赖于另一个 promise 的 promise 并等待:
var targetFolder = null;
var targetPromise = Windows.Storage.KnownFolders.documentsLibrary.getFolderAsync( target ).then( function() {
return Windows.Storage.KnownFolders.documentsLibrary.getFolderAsync( target );
}, function(error) {
return Windows.Storage.KnownFolders.documentsLibrary.createFolderAsync( target );
});
targetPromise.then( function(folder) {
targetFolder = folder;
});
这并不理想,但我将对 getFolderAsync
的第一次调用视为“存在”调用。然后使用成功回调返回 getFolderAsync
的结果。如果“exists”失败,则会调用 createFolderAsync
。这意味着 $q.all( sourcePromise, targetPromise )
将等待,直到检索(或创建)文件夹。为了简单起见,我只是检查 targetFolder
是否已定义,而不是捕获 createFolderAsync
的失败回调。
尽管这在技术上回答了我问题的第一部分。我意识到以下内容更加简洁:
var replace = Windows.Storage.CreationCollisionOption.replaceExisting;
var targetFolder = null;
var targetPromise = Windows.Storage.KnownFolders.documentsLibrary.createFolderAsync(target, replace);
targetPromise.then( function(folder) {
targetFolder = folder;
});
我不确定的是 targetPromise.then
是否在 $q.all
(在函数末尾使用)之前按顺序执行。它似乎有效,但我不确定它是否应该有效。
我还创建了一个函数,它将生成 promise 并等待每个复制操作(在解决单个延迟 promise 之前)。这只是第一个有效的版本。任何有关如何改进它的建议将不胜感激:
$scope.copyFolderRecursively = function(sourceFolder, targetFolder) {
function CopySubFolders(sourcefolder, targetFolder) {
var deferred = $q.defer();
if ( !sourceFolder ) return false;
var promises = [];
// Copy the files
var getFilesPromise = sourceFolder.getFilesAsync();
var copyFilesPromise = getFilesPromise.then(function (files) {
if ( files ) {
files.forEach(function (file) {
console.log("copy file: " + file.displayName);
var delayed = $q.defer();
promises.push( delayed.promise );
file.copyAsync(targetFolder).then( function(copiedfile) {
delayed.resolve( copiedfile );
}, function(error) {
delayed.reject( "Error copying file" + file.path );
});
});
}
});
// Recursively copy each subfolder
var getFoldersPromise = sourceFolder.getFoldersAsync();
var copyFoldersPromise = getFoldersPromise.then(function (folders) {
if ( folders ) {
folders.forEach(function (folder) {
var replace = Windows.Storage.CreationCollisionOption.replaceExisting;
console.log("create folder: " + folder.name);
var delayed = $q.defer();
promises.push( delayed.promise );
targetFolder.createFolderAsync(folder.name, replace).then(function (newFolder) {
CopySubFolders(folder, newFolder).then( function(success) {
delayed.resolve( newFolder );
}, function(error) {
delayed.reject( "Error copying folder " + newFolder.path );
});
});
});
}
});
$q.all( getFilesPromise, copyFilesPromise, getFoldersPromise, copyFoldersPromise, promises ).then( function() {
return $q.all( promises );
}).then( function() {
deferred.resolve( true );
}, function(error) {
deferred.resolve( false );
});
return deferred.promise;
}
return CopySubFolders( sourceFolder, targetFolder );
}
此解决方案值得注意的一件事(另一个实现),UWP promises不是Angularjs promises 。我基本上将每个 UWP 调用转换为 AngularJS 延迟 promise - 所以我可以使用 $q.all()
。
关于javascript - Cordova/UWP - 如何顺序处理 Promise 并编写例程来递归复制文件夹,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44866344/
uwp 和非 uwp 应用程序之间是否可以进行通信。我的非uwp是一个提供服务的后台任务。我想在 uwp 应用程序中调用该非 uwp 服务。 如何调用电话? AppServiceConnection
我正在开发一个应用程序,该应用程序旨在在具有多个显示器(从 1 到 3必要)在每个监视器上,每个监视器都显示不同的 View 。 就我所见,UWP 并不自然适用于这种情况。我设法使用 CoreAppl
我正在尝试对UWP应用使用broadFileSystemAccess功能,但是package.appxmanifest的功能列表中未列出broadFileSystemAccess功能。 我的最低和最高
有时我有一个打开的流或一个事件的队列,必须在应用程序关闭时正确处理。在 WPF 应用程序中,我可以在应用程序上使用 Unloading 事件,但在 UWP 中我注意到这样的事件不存在。 我如何可靠地做
http://wikisend.com/download/880354/UWP_Server.zip 我已将代码上传至上述网址。 它是 UWP 中的客户端和服务器应用程序。这里客户端和服务器都在同一个
大家好 我知道这个问题(Chromium working on UWP)之前(2015/2016)有人问过,想看看有没有更新 我正在尝试在 UWP 应用程序中使用 CEF3 构建,但在运行该应用程序时
我目前正在构建一个应用程序,它可以使用 Windows 游戏 DVR 在某个时刻开始录制屏幕。该录音机在完成录音时将应用程序名称作为文件名。 我发现了如何使用 Applicationview.GetF
我已使用 Desktop App Converter 将我的 WPF 应用程序转换为 appx 包。我需要在资源管理器上下文菜单中有一个项目。 IE。用户右键单击文件并在主菜单中看到我的项目“对应用程
我想稍微修改一个 Button 控件(添加描述)。在哪里可以找到 UWP 控件的默认控件模板? 最佳答案 似乎可以在以下位置找到它们: C:\Program Files (x86)\Windows K
我想通过 UWP 应用访问 windows10 注册表项。 键为:\HKEY_LOCAL_MACHINE\SOFTWARE\MyCompanyName\MyName 我找不到任何函数调用来完成它。 请
我开发了一个 UWP appx,它可以安装在 cmd.exe 提示符中: C:\test>myapp.appx 但是在安装过程中会弹出一个 Windows GUI。 有没有什么方法 使用 Silent
在我的 UWP 应用程序中,如何通过 UpdateTask 中的代码进行调试? VS 2017 中的“生命周期事件”下拉菜单似乎没有提供触发此类后台任务的选项。有办法实现吗? 最佳答案 首先是关于 U
我尝试在 VS 2017 中创建一个 UWP 应用程序包。 创建时我收到一条神秘的错误消息:严重性代码描述项目文件行抑制状态错误 0xdef00532 - 资源“Files/Assets/Square
我有一个 TextBlock在我的应用程序中。我要办理pinch in & out在它上面调整字体的大小。当ManipulationDelta事件触发我检查Scale属性(property),但大多数
为什么默认选择的索引不起作用?它因平台异常而崩溃: RumTime 错误: Exception thrown at 0x00007FFDEF7F7788 (KernelBase.dll) in ab
有没有办法在同一个包中的 UWP 应用程序和桌面桥应用程序之间共享互斥锁?它们似乎有不同的命名空间;使用相同的名称不会在进程之间产生相同的对象。根据 WinObj,UWP 应用程序的对象是,存储在 A
有什么方法可以检测当前的 UWP 要退出 ? (由用户关闭或终止进程) 我想向服务器发送一些关于应用程序将断开连接的请求,还想在退出之前保存一些数据。 最佳答案 无法检测这种情况或阻止用户终止您的应用
我正在使用 XAML 和 C# 开发通用 Windows 平台应用程序。我想在 UWP 中更改焦点上 TextBox 的边框颜色。 在此先感谢您的帮助。 最佳答案 其实实现起来很简单,按照以下步骤即可
是否可以在 UWP 应用中更改甚至隐藏鼠标指针? 我唯一能找到的是: Windows.UI.Xaml.Window.Current.CoreWindow.PointerCursor = null; 但
我是一名优秀的程序员,十分优秀!