如何等待JavaScript Promise解析后再恢复函数?
我正在做一些单元测试。测试框架将页面加载到 iFrame 中,然后对该页面运行断言。在每个测试开始之前,我创建一个设置 iFrame 事件调用、设置 iFrame 的事件并返回 promise。Promise
onload
resolve()
src
因此,我可以调用 ,它将等待页面加载,然后再执行任何内容。loadUrl(url).then(myFunc)
myFunc
我在测试中到处使用这种模式(不仅仅是为了加载URL),主要是为了允许对DOM进行更改(例如,模仿单击按钮,并等待divs隐藏和显示)。
这种设计的缺点是,我经常编写带有几行代码的匿名函数。此外,虽然我有一个解决方法(QUnit),但定义承诺的测试函数在承诺运行之前完成。assert.async()
我想知道是否有任何方法可以从a中获取值或等待(块/睡眠)直到它得到解决,类似于.网的.我知道JavaScript是单线程的,但我希望这并不意味着一个函数不能屈服。Promise
IAsyncResult.WaitHandle.WaitOne()
从本质上讲,有没有办法让以下内容以正确的顺序吐出结果?
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>