scroll-behavior属性使用方法

定义和用法:

scroll-behavior 属性规定当用户单击可滚动框中的链接时,是否平滑地(具动画效果)滚动位置,而不是直线跳转。

html 复制代码
<style>
    element{
      /* 核心代码 */
      scroll-behavior: smooth;
    }
</style>

属性值:

描述
auto 默认值。允许在滚动框内的元素间直接跳转的"滚动效果"。
smooth 允许在滚动框内的元素间平滑的"滚动效果"。

效果展示:

说明:点击侧边栏的数字,实现左侧模块间的滚动切换效果

详细代码:

html 复制代码
<style>
    a {
      display: inline-block;
      width: 20px;
      text-decoration: none;
      color: #000;
    }

    nav {
      position: absolute;
      top: 50px;
      left: 300px;
      width: 20px;
      text-align: center;
      border: 1px solid black;
      z-index: 1;
    }

    scroll-container {
      /* 核心代码:缓慢滚动过渡 */
      scroll-behavior: smooth;
      display: block;
      width: 350px;
      height: 200px;
      overflow-y: scroll;
      border: 1px solid #ccc;
    }

    scroll-page {
      position: relative;
      display: flex;
      align-items: center;
      justify-content: center;
      height: 100%;
      font-size: 2em;
    }
</style>
html 复制代码
<body>
  <nav>
    <a href="#page-1">1</a>
    <a href="#page-2">2</a>
    <a href="#page-3">3</a>
    <a href="#page-4">4</a>
    <a href="#page-5">5</a>
  </nav>
  <scroll-container>
    <scroll-page id="page-1">模块1</scroll-page>
    <scroll-page id="page-2">模块2</scroll-page>
    <scroll-page id="page-3">模块3</scroll-page>
    <scroll-page id="page-4">模块4</scroll-page>
    <scroll-page id="page-5">模块5</scroll-page>
  </scroll-container>
</body>
相关推荐
@大迁世界6 小时前
Vue 设计模式 实战指南
前端·javascript·vue.js·设计模式·ecmascript
jump_jump7 小时前
妙用 localeCompare 获取汉字拼音首字母
前端·javascript·浏览器
U.2 SSD7 小时前
Echarts单轴坐标系散点图
前端·javascript·echarts
不做无法实现的梦~7 小时前
jetson刷系统之后没有浏览器--解决办法
开发语言·javascript·ecmascript
Jedi Hongbin8 小时前
Three.js NodeMaterial 节点材质系统文档
前端·javascript·three.js·nodematerial
前端小马8 小时前
前后端Long类型ID精度丢失问题
java·前端·javascript·后端
liu****10 小时前
基于websocket的多用户网页五子棋(八)
服务器·前端·javascript·数据库·c++·websocket·个人开发
San3010 小时前
深入理解 JavaScript 函数:从基础到高阶应用
前端·javascript·node.js
芒果茶叶10 小时前
并行SSR,SSR并行加载
前端·javascript·架构
威风的虫11 小时前
JavaScript中的axios
开发语言·javascript·ecmascript