0

0

html如何实现平滑滚动 页面平滑滚动效果设置

穿越時空

穿越時空

发布时间:2025-06-25 18:42:02

|

863人浏览过

|

来源于php中文网

原创

实现页面平滑滚动主要有两种方式:1.css scroll-behavior,通过设置html或特定元素的scroll-behavior属性实现平滑滚动,优点是简单易用但兼容性较差且无法自定义动画细节;2.javascript实现,使用window.scrollto()或requestanimationframe()方法,可灵活控制滚动速度和缓动函数,兼容性好但代码量较多;对于不支持scroll-behavior的浏览器可采用javascript方案作为备选,也可针对特定容器应用平滑滚动并修正偏移量;自定义滚动速度可通过修改duration参数实现,缓动函数则可通过替换easeinoutcubic等函数来调整效果。

html如何实现平滑滚动 页面平滑滚动效果设置

页面平滑滚动,简单来说,就是让页面滚动的时候,不是“嗖”的一下跳到目标位置,而是有一个平滑过渡的动画效果。实现起来并不复杂,主要通过CSS和JavaScript来实现。

html如何实现平滑滚动 页面平滑滚动效果设置

解决方案

实现平滑滚动主要有两种方式:CSS scroll-behavior 和 JavaScript。

html如何实现平滑滚动 页面平滑滚动效果设置

1. CSS scroll-behavior

立即学习前端免费学习笔记(深入)”;

这是最简单的方式,只需要一行CSS代码:

html如何实现平滑滚动 页面平滑滚动效果设置
html {
  scroll-behavior: smooth;
}

这行代码会使整个页面的所有锚点链接都具有平滑滚动效果。 如果想只对特定元素应用平滑滚动,可以将其应用到该元素上,比如:

.scrollable-area {
  scroll-behavior: smooth;
  overflow-y: auto; /* 确保元素可以滚动 */
}

优点:简单易用,代码量少。

缺点:兼容性略差,一些老版本的浏览器可能不支持。另外,无法自定义滚动动画的细节,例如滚动速度、缓动函数等。

2. JavaScript 实现

JavaScript 实现方式更加灵活,可以自定义滚动动画的各种参数。

a. 使用 window.scrollTo()element.scrollTo()

document.querySelectorAll('a[href^="#"]').forEach(anchor => {
  anchor.addEventListener('click', function (e) {
    e.preventDefault();

    const targetId = this.getAttribute('href').substring(1);
    const targetElement = document.getElementById(targetId);

    if (targetElement) {
      window.scrollTo({
        top: targetElement.offsetTop,
        behavior: 'smooth'
      });
    }
  });
});

这段代码会监听页面上所有以 # 开头的链接的点击事件,阻止默认跳转行为,然后使用 window.scrollTo() 方法滚动到目标元素的位置。 behavior: 'smooth' 指定了平滑滚动。

b. 使用 requestAnimationFrame() 实现更精细的动画控制

如果需要更精细的动画控制,例如自定义缓动函数,可以使用 requestAnimationFrame()

function smoothScroll(element, target, duration) {
  let start = element.scrollTop;
  let change = target - start;
  let startTime = performance.now();

  function easeInOutCubic(t) {
    t /= duration / 2;
    if (t < 1) return change / 2 * t * t * t + start;
    t -= 2;
    return change / 2 * (t * t * t + 2) + start;
  }

  function animateScroll() {
    const currentTime = performance.now() - startTime;
    if (currentTime < duration) {
      element.scrollTop = easeInOutCubic(currentTime);
      requestAnimationFrame(animateScroll);
    } else {
      element.scrollTop = target;
    }
  }

  requestAnimationFrame(animateScroll);
}

document.querySelectorAll('a[href^="#"]').forEach(anchor => {
  anchor.addEventListener('click', function (e) {
    e.preventDefault();

    const targetId = this.getAttribute('href').substring(1);
    const targetElement = document.getElementById(targetId);

    if (targetElement) {
      smoothScroll(document.documentElement || document.body, targetElement.offsetTop, 500); // 500ms 滚动时间
    }
  });
});

这个例子使用了 requestAnimationFrame() 和一个 easeInOutCubic 缓动函数来实现更平滑、更可控的滚动动画。 easeInOutCubic 是一种常用的缓动函数,可以产生先加速后减速的效果。

Grokipedia
Grokipedia

xAI推出的AI在线百科全书

下载

优点:兼容性好,可以自定义滚动动画的各种参数,灵活性高。

缺点:代码量相对较多,需要一定的 JavaScript 基础。

如何兼容不支持scroll-behavior的浏览器?

对于不支持 scroll-behavior 的老版本浏览器,可以采用 JavaScript 方案作为备选方案。检测浏览器是否支持 scroll-behavior,如果不支持,则使用 JavaScript 实现平滑滚动。

if ('scrollBehavior' in document.documentElement.style) {
  // 支持 scroll-behavior,使用 CSS 实现
  document.documentElement.style.scrollBehavior = 'smooth';
} else {
  // 不支持 scroll-behavior,使用 JavaScript 实现
  document.querySelectorAll('a[href^="#"]').forEach(anchor => {
    anchor.addEventListener('click', function (e) {
      e.preventDefault();

      const targetId = this.getAttribute('href').substring(1);
      const targetElement = document.getElementById(targetId);

      if (targetElement) {
        // 使用 JavaScript 实现平滑滚动 (上面的 JavaScript 代码)
        smoothScroll(document.documentElement || document.body, targetElement.offsetTop, 500);
      }
    });
  });
}

这样可以确保在所有浏览器上都能实现平滑滚动效果。

如何实现指定容器内的平滑滚动?

有时候,我们希望只对页面中的某个特定容器(例如一个 div)应用平滑滚动效果,而不是整个页面。 这时候,需要针对该容器进行设置。

CSS 方法:

.scrollable-container {
  height: 300px; /* 设置容器高度 */
  overflow-y: scroll; /* 允许垂直滚动 */
  scroll-behavior: smooth;
}

然后,容器内的锚点链接会自动平滑滚动。

JavaScript 方法:

修改 JavaScript 代码,将 window.scrollTo 替换为容器的 scrollTo 方法:

document.querySelectorAll('.scrollable-container a[href^="#"]').forEach(anchor => {
  anchor.addEventListener('click', function (e) {
    e.preventDefault();

    const targetId = this.getAttribute('href').substring(1);
    const targetElement = document.getElementById(targetId);

    if (targetElement && targetElement.parentNode.classList.contains('scrollable-container')) {
      document.querySelector('.scrollable-container').scrollTo({
        top: targetElement.offsetTop - targetElement.parentNode.offsetTop, // 修正偏移量
        behavior: 'smooth'
      });
    }
  });
});

注意,这里需要修正偏移量,因为目标元素相对于容器的 offsetTop 可能不是 0。

如何自定义滚动速度和缓动函数?

使用 CSS 的 scroll-behavior 无法自定义滚动速度和缓动函数。 需要使用 JavaScript 来实现。

在上面的 JavaScript 示例中,已经展示了如何使用 requestAnimationFrame() 和自定义缓动函数来实现更精细的动画控制。 可以修改 smoothScroll 函数的 duration 参数来调整滚动速度,修改 easeInOutCubic 函数来调整缓动效果。

例如,要将滚动速度减慢一倍,可以将 duration 参数设置为 1000 (单位是毫秒)。

要使用不同的缓动函数,可以替换 easeInOutCubic 函数。 有很多现成的缓动函数可以使用,例如 linear, easeInQuad, easeOutQuad, easeInOutQuad 等。 也可以自定义缓动函数,只要保证函数接受一个 0 到 1 之间的数值作为输入,并返回一个 0 到 1 之间的数值作为输出即可。

function easeOutBounce(x) {
  const n1 = 7.5625;
  const d1 = 2.75;

  if (x < 1 / d1) {
    return n1 * x * x;
  } else if (x < 2 / d1) {
    return n1 * (x -= (1.5 / d1)) * x + 0.75;
  } else if (x < 2.5 / d1) {
    return n1 * (x -= (2.25 / d1)) * x + 0.9375;
  } else {
    return n1 * (x -= (2.625 / d1)) * x + 0.984375;
  }
}

这个 easeOutBounce 缓动函数会产生一个类似弹跳的效果。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

7

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

7

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

1

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

1

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

16

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

18

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 25万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号