首页 >web前端 >js教程 >如何实现锚链接平滑滚动?

如何实现锚链接平滑滚动?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-16 22:42:18991浏览

How Can I Implement Smooth Scrolling for Anchor Links?

通过锚链接实现平滑滚动

在帮助部分中合并常见问题解答的超链接是引导用户获取特定信息的常见方法。虽然锚链接可以使页面滚动到目标位置,但实现流畅的滚动体验可以增强用户交互。

本机和基于 jQuery 的解决方案

最新版本的浏览器现在支持平滑锚点滚动的本机解决方案。

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

    document.querySelector(anchor.getAttribute('href')).scrollIntoView({
      behavior: 'smooth'
    });
  });
});

为了更广泛的浏览器兼容性,jQuery 提供了替代方案技巧:

$(document).on('click', 'a[href^="#"]', function (event) {
  event.preventDefault();

  $('html, body').animate({
    scrollTop: $($.attr(this, 'href')).offset().top
  }, 500);
});

此外,jQuery 会处理目标元素没有 ID 的情况。

 $('a[href^="#"]').click(function () {
    $('html, body').animate({
        scrollTop: $('[name="' + $.attr(this, 'href').substr(1) + '"]').offset().top
    }, 500);

    return false;
});

性能优化

缓存 $('html, body') 选择器可以显着提高

var $root = $('html, body');

$('a[href^="#"]').click(function () {
    $root.animate({
        scrollTop: $( $.attr(this, 'href') ).offset().top
    }, 500);

    return false;
});

更新 URL

如果需要在滚动时更新 URL,可以在动画回调中实现。

var $root = $('html, body');

$('a[href^="#"]').click(function() {
    var href = $.attr(this, 'href');

    $root.animate({
        scrollTop: $(href).offset().top
    }, 500, function () {
        window.location.hash = href;
    });

    return false;
});

以上是如何实现锚链接平滑滚动?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn