vue 中滚动条始终定位在底部的方法

文章讲述了在Vue中实现类似ChatGPT的聊天回答功能时,如何保证滚动条始终定位在底部。作者通过动态修改滚动条位置遇到问题,发现需在数据变化后DOM更新完成时执行操作,最终通过`nextTick`函数解决了这个问题。
摘要由CSDN通过智能技术生成

需求描述:需要模仿chatgpt一样的聊天回答功能
遇到问题:固定高度 到最后不会滚动到最底部

vue 中滚动条始终定位在底部的方法
滚动条定位在底部,首先想到的是,动态修改滚动条到顶部的距离等于div的高度,

代码实现:

var div = document.getElementById(‘data-list-content’)
div.scrollTop = div.scrollHeight

但是问题来了,滚动条并没有到达底部,而是距离底部还有一点距离(一脸懵逼)

估计是动态加载数据时,数据还未加载,滚动条就已经执行,知道原因了,那就实践呗。

第二次尝试,利用vue的watch监控数据的改变,然后动态修改滚动条到顶部的距离

代码实现:

watch: {

‘processData’: ‘scrollToBottom’

}

scrollToBottom: function () {

var div = document.getElementById(‘data-list-content’)

div.scrollTop = div.scrollHeight

}
再次崩溃了没有实现

这个时候我想到了 n e x t T i c k 。简单的介绍下 nextTick 。 简单的介绍下 nextTick。简单的介绍下nextTick:
Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新。
n e x t T i c k 是在下次 D O M 更新循环结束之后执行延迟回调,在修改数据之后使用。既然 nextTick 是在下次 DOM 更新循环结束之后执行延迟回调,在修改数据之后使用 。 既然 nextTick是在下次DOM更新循环结束之后执行延迟回调,在修改数据之后使用。既然nextTick是在下次DOM更新时执行的,不正好符合我们的要求嘛(小激动)。
代码实现:

watch: {

‘processData’: ‘scrollToBottom’

}

scrollToBottom: function () {

this.$nextTick(() => {

var div = document.getElementById('data-list-content')

div.scrollTop = div.scrollHeight

})

}
运行代码,成功了。

以上这篇vue 中滚动条始终定位在底部的方法就是小编分享给大家的全部内容了,希望能给大家一个参考.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值