文章目录
- 效果1
- 效果 2
- 滚动到最上方
效果1

import {CaretUpOutlined,CaretDownOutlined} from "@ant-design/icons";
const wrap = useRef<HTMLDivElement | null>(null);
const scrollTo = useCallback(
  // dir:0 向下滚动  1 向上滚动
  (dom, height, dir = 0) =>
    () => {
      const sTop = dom.scrollTop;
      const valid = dir ? sTop > height : sTop < height;
      if (valid) {
        window.requestAnimationFrame(scrollTo(dom, height, dir));
        const diff = Math.abs(sTop - height);
        const dis = diff / 8;
        //差距不足 8 时滚动 4 2 1 0
        const nextScrollDis = dis < 1 ? Math.ceil(diff / 2) : dis;
        let y = sTop - nextScrollDis;
        // 向下滚动
        !dir && (y = sTop + nextScrollDis);
        dom.scrollTo(0, y);
      }
    },
  []
);
const onDownScroll = useCallback(() => {
  const { offsetHeight, scrollTop, scrollHeight } =
    wrap.current as HTMLDivElement;
  const maxHeight = scrollHeight - offsetHeight;
  const target = offsetHeight + scrollTop;
  scrollTo(wrap.current, target > maxHeight ? maxHeight : target)();
}, [scrollTo]);
const onUpScroll = useCallback(() => {
  const { offsetHeight, scrollTop } = wrap.current as HTMLDivElement;
  const target = scrollTop - offsetHeight;
  scrollTo(wrap.current, target < 0 ? 0 : target, 1)();
}, [scrollTo]);
return (
    <Container ref={wrap}>
      <TotalTitle>
        <span data-fill>
          TOTAL: <b>{pokerList.length}</b>
        </span>
        <CaretUpOutlined onClick={onUpScroll} />
        <CaretDownOutlined onClick={onDownScroll} />
      </TotalTitle>
      .....效果 2

思路
 第一次 滚动100 的10分之一 ,一次时 100-10的十分之一,下下次是 100-10-10的十分之一 依次类推
 看起来就会一点点慢下来
//! 移动最小1 0.x不能移动
export const animateScrollToTop = (top: number, element: HTMLElement) => () => {
const { scrollTop, scrollHeight, clientHeight } = element;
if (clientHeight + scrollTop < scrollHeight) {
const diff = top - scrollTop;
// console.log(top, scrollTop, diff);
const dis = diff / 6;
// const scrollDis = dis < 1 ? 1 : dis;
const scrollDis = dis < 1 ? Math.ceil(diff / 2) : dis;
if (scrollTop < top) {
requestAnimationFrame(animateScrollToTop(top, element));
element.scrollTo(0, scrollTop + scrollDis);
}
}
};
滚动到最上方
export const scrollToTop = () => {
  let sTop = document.documentElement.scrollTop || document.body.scrollTop;
  if (sTop > 0) {
    window.requestAnimationFrame(scrollToTop);
    window.scrollTo(0, sTop - sTop / 8);
  }
};                










