需求描述:需要模仿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 中滚动条始终定位在底部的方法就是小编分享给大家的全部内容了,希望能给大家一个参考.