(已解决)scrollIntoView和scrollTo方法实现滚动条具体定位无效,offsetTop值不准确

想实现父元素滚动条效果,子元素可以动态的改变定位,定位到父元素顶部
但是子元素的高度是不固定的,所以网上很多方法不具有参考价值
我开始实现用了scrollHeight来加子元素的高度实现,后来发现加完后高度总会高出来一部分,以下就是我找了一天时间踩的坑

(1)子元素父元素之间 需要有明确的关系

类似这样 多个span 被div包着那么div必须要有position定位 (2) 是否有高度塌陷问题
我踩的坑就是我div2给设置了固定高度50px 在计算滚动条还是offsetTop得时候span 获取到的值就不准确,因为我span是不固定高度的,所以就存在着Dom元素偏移,子元素塌陷的问题,只需要给div1与span之间的元素都改成自动计算高度即可 height:auto (3)scrollIntoView是子元素的方法 而 scrollTo是父元素的方法
 child.scrollIntoView({ behavior: 'smooth', block: 'start', inline: 'nearest' });
parent.scrollTo({
                    top: child.offsetTop,
                    behavior: "smooth"
                });

以上 parent和child都是指代的dom元素 可以用refs来取也可以用getElementById取

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值