【发布时间】:2019-07-18 20:16:40
【问题描述】:
我正在尝试使用 RXJS 实现平滑滚动功能。
以下代码平滑滚动,但未按预期滚动。比达到目标所需的时间要长得多。
知道怎么解决吗?
const scrollableEl = document.getElementById('view');
const btn = document.getElementById('testBtn');
btn.addEventListener('click', () => {
scrollTo(scrollableEl, 1000, 300);
});
function scrollTo(scrollableEl: HTMLElement, point: number, duration: number) {
timer(0, 20, animationFrame).pipe(
map((elapsedTime: number) => {
const delta = point - scrollableEl.offsetTop;
return {
top: easeInOutQuad(elapsedTime, scrollableEl.offsetTop, delta, duration),
elapsedTime
};
}),
tap((target) => {
console.log('scrollTo: ', target);
scrollableEl.scrollTop = target.top;
}),
// Stop timer
takeWhile((target: any) => target.elapsedTime < duration)
).subscribe();
}
【问题讨论】:
标签: javascript typescript rxjs smooth-scrolling