我正在进行一些单元测试。测试框架将一个页面加载到iFrame中,然后对该页面运行断言。在每个测试开始之前,我都会创建一个
因此,我只需调用
我在我的测试中(不仅限于加载 URL),经常使用这种模式,主要是为了允许 DOM 发生更改(例如模拟单击按钮,并等待 div 显示和隐藏)。
这种设计的缺点是,我不断地编写具有几行代码的匿名函数。此外,虽然我有一种解决方法(QUnit 的
我想知道是否有任何方法可以从
实质上,是否有一种方法可以使以下内容以正确的顺序输出结果?
Promise
,该 Promise 会将 iFrame 的 onload
事件设置为调用 resolve()
,设置 iFrame 的 src
,并返回 Promise。因此,我只需调用
loadUrl(url).then(myFunc)
,它就会在执行任何 myFunc
之前等待页面加载。我在我的测试中(不仅限于加载 URL),经常使用这种模式,主要是为了允许 DOM 发生更改(例如模拟单击按钮,并等待 div 显示和隐藏)。
这种设计的缺点是,我不断地编写具有几行代码的匿名函数。此外,虽然我有一种解决方法(QUnit 的
assert.async()
),但定义 Promises 的测试函数在 promise 运行之前就完成了。我想知道是否有任何方法可以从
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>
.then(fnAppend.bind(myDiv))
,这可以大大减少匿名函数。 - dandavis