原生js写数据自动纵向滚动,鼠标移入后停止滚动可手动滚动,鼠标移出转自动

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>滚动页面</title>
  <link rel="stylesheet" href="styles.css">
  <style>
    body,
    html {
      margin: 0;
      padding: 0;
      overflow: hidden;
    }

    #scrollContainer {
      width: 100%;
      height: 100vh;
      overflow: hidden;
      position: relative;
    }

    #scrollContent {
      display: flex;
      flex-direction: column;
      transition: transform 0.3s ease;
    }

    .item {
      width: 100%;
      height: 100vh;
      display: flex;
      justify-content: center;
      align-items: center;
      font-size: 5em;
      color: white;
    }

    .item:nth-child(odd) {
      background-color: #333;
    }

    .item:nth-child(even) {
      background-color: #666;
    }
  </style>
</head>

<body>
  <div id="scrollContainer">
    <div id="scrollContent">
      <div class="item">1</div>
      <div class="item">2</div>
      <div class="item">3</div>
      <div class="item">4</div>
      <div class="item">5</div>
    </div>
  </div>
</body>

<script>
  const scrollContainer = document.getElementById('scrollContainer');
  const scrollContent = document.getElementById('scrollContent');
  
  let currentPosition = 0;
  let intervalId = null;
  const scrollDistance = 2;
  const itemHeight = scrollContent.clientHeight / scrollContent.children.length;
  const maxScrollPosition = 0;
  const minScrollPosition = -itemHeight * (scrollContent.children.length - 1);

  function autoScroll() {
    if (currentPosition <= minScrollPosition) {
      currentPosition = 0;
    }
    scrollContent.style.transform = `translateY(${currentPosition}px)`;
    currentPosition -= scrollDistance;
  }

  function startAutoScroll() {
    intervalId = setInterval(autoScroll, 20);
  }

  function stopAutoScroll() {
    clearInterval(intervalId);
  }

  function handleWheel(event) {
    currentPosition -= event.deltaY;
    if (currentPosition > maxScrollPosition) {
      currentPosition = maxScrollPosition;
    } else if (currentPosition < minScrollPosition) {
      currentPosition = minScrollPosition;
    }
    scrollContent.style.transform = `translateY(${currentPosition}px)`;
  }

  scrollContainer.addEventListener('mouseenter', function () {
    stopAutoScroll();
    scrollContainer.addEventListener('wheel', handleWheel);
  });

  scrollContainer.addEventListener('mouseleave', function () {
    scrollContainer.removeEventListener('wheel', handleWheel);
    startAutoScroll();
  });

  startAutoScroll();
</script>

</html>
  • 初始化变量(currentPositionintervalIdscrollDistanceitemHeightmaxScrollPositionminScrollPosition),用于跟踪滚动状态和动画。
  • autoScroll()函数持续地将scrollContent向上移动(translateY),直到达到minScrollPosition,然后重置。
  • startAutoScroll()stopAutoScroll()函数通过setIntervalclearInterval控制自动滚动动画。
  • handleWheel(event)函数根据鼠标滚轮事件(wheel)调整currentPosition,确保滚动保持在maxScrollPositionminScrollPosition定义的范围内。
  • scrollContainer上的事件监听器(mouseentermouseleave)触发自动滚动停止/开始,并启用/禁用通过鼠标滚轮进行手动滚动。
  • mouseenter时,自动滚动停止,并且可以通过鼠标滚轮进行手动滚动。
  • mouseleave时,手动滚动停止,并且自动滚动恢复。
  • #scrollContent中的每个项目占满视口高度,页面可以通过自动或手动方式平滑滚动这些项目。
相关推荐
GISer_Jing1 小时前
前端面试通关:Cesium+Three+React优化+TypeScript实战+ECharts性能方案
前端·react.js·面试
落霞的思绪2 小时前
CSS复习
前端·css
咖啡の猫4 小时前
Shell脚本-for循环应用案例
前端·chrome
百万蹄蹄向前冲6 小时前
Trae分析Phaser.js游戏《洋葱头捡星星》
前端·游戏开发·trae
朝阳5817 小时前
在浏览器端使用 xml2js 遇到的报错及解决方法
前端
GIS之路7 小时前
GeoTools 读取影像元数据
前端
ssshooter7 小时前
VSCode 自带的 TS 版本可能跟项目TS 版本不一样
前端·面试·typescript
你的人类朋友8 小时前
【Node.js】什么是Node.js
javascript·后端·node.js
Jerry8 小时前
Jetpack Compose 中的状态
前端
dae bal9 小时前
关于RSA和AES加密
前端·vue.js