页面锚点,点击跳转页面某固定位置(scrollIntoView)

常用场景:页面锚点,点击跳转页面某固定位置

1.element.scrollToView()

    (1)当页面有fixed顶部的布局时,由于fixed布局的元素脱离文档流,被scrollToView()的元素会被置顶到页面最顶部,导致部分被fixed布局的元素遮挡,因此不太适用。

   (2)可用于页面没有fixed布局,常见的是顶部需要固定位置时可用element.scrollToView(),但是当点击的元素没有当前页面的高度(100vh)时,会出现整个页面上移的情况。

    此时可用的解决办法是将最外层容器元素设置为fixed布局

.box{

position: fixed;
top:0;
left:0;
right:0;
bottom:0;
overflow-y: scroll;

}

 

用法:

<div id="anchorName">123</div>

 

  scrollToAnchor = (anchorName) => {
    if (anchorName) {
      let anchorElement = document.getElementById(anchorName); //取到需要移动的元素
      if (anchorElement) {
        anchorElement.scrollIntoView({
          behavior: 'smooth',
        });
      }
    }
 

2.element.scroll()

    此方法比较通用,不管页面有何布局都可以用,计算元素离顶部的距离,然后向上移动对应的距离即可

scrollToAnchor = () => {
  let element = document.getElementById('xx');
  let height = document.getElementById('xx').offsetTop; //计算需要向上移动的距离
  element.scroll({
    top: height, //向上移动的距离,如果有fixede布局, 直接减去对应距离即可
    behavior: 'smooth', // 平滑移动
  });
}

scrollIntoView详细文档:

https://developer.mozilla.org/zh-cn/docs/web/api/element/scrollintoview

建议使用第二种方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

.︶ㄣ☆.'龍

你的鼓励将是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值