最佳答案
我在做一些单元测试。测试框架将一个页面加载到 iFrame 中,然后对该页面运行断言。在每次测试开始之前,我创建一个 Promise
,它设置 iFrame 的 onload
事件来调用 resolve()
,设置 iFrame 的 src
,并返回承诺。
因此,我可以调用 loadUrl(url).then(myFunc)
,它将等待页面加载后再执行 myFunc
。
我在测试中到处使用这种模式(不仅仅是为了加载 URL) ,主要是为了允许对 DOM 进行更改(例如,模仿单击一个按钮,等待 div 隐藏和显示)。
这种设计的缺点是,我经常编写只有几行代码的匿名函数。此外,虽然我有一个解决方案(QUnit 的 assert.async()
) ,但是定义承诺的测试函数在运行承诺之前就完成了。
我想知道是否有任何方法可以从 Promise
获得一个值或者等待(块/睡眠)直到它得到解决,类似于。NET 的 IAsyncResult.WaitHandle.WaitOne()
。我知道 JavaScript 是单线程的,但我希望这并不意味着函数不能生成。
本质上,有没有一种方法可以让下面的结果以正确的顺序显示出来?
function kickOff() {
return new Promise(function(resolve, reject) {
$("#output").append("start");
setTimeout(function() {
resolve();
}, 1000);
}).then(function() {
$("#output").append(" middle");
return " end";
});
};
function getResultFrom(promise) {
// todo
return " end";
}
var promise = kickOff();
var result = getResultFrom(promise);
$("#output").append(result);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="output"></div>