1

我正在尝试编写一个测试,当元素在视口中时断言某些东西。

我正在使用IntersectionObserverAPI,事实证明,当浏览器可以发出对观察者的调用时,它们的调用就完成了。

所以问题是,我应该如何处理这样的断言?我应该等一段时间吗?多少毫秒就够了?是否有事件知道浏览器何时完成调用观察者?

目前我正在这样做:

// ... do whatever to make the code observe some elements
document.scrollingElement.scrollTop = window.innerHeight;

// Wait for observer to kick in (tried 1, 5, millis, 10 seems to work)
await new Promise(resolve => setTimeout(resolve, 10));

sinon.assert.calledWith(spy, dom.querySelector(selector));

这行得通,但我想知道是否有比等待一段时间更好的方法。

4

1 回答 1

1

好问题,您应该尝试使用requestAnimationFrame,但使用两次。

例如:

await new Promise(resolve => requestAnimationFrame(requestAnimationFrame(resolve))) 
于 2019-03-05T07:32:49.147 回答