700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > vue watch 修改滚动条_Vue.js 中滚动条始终定位在底部的方法

vue watch 修改滚动条_Vue.js 中滚动条始终定位在底部的方法

时间:2019-12-11 18:44:13

相关推荐

vue watch 修改滚动条_Vue.js 中滚动条始终定位在底部的方法

Vue.js 中滚动条始终定位在底部的方法

发布于 -2-23|

复制链接

分享一篇关于vue 中滚动条始终定位在底部的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小妖过来看看吧

滚动条定位在底部,首先想到的是,动态修改滚动条到顶部的距离等于div的高度,代码实现:

```javascript

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

div.scrollTop = div.scrollHeight

```

但是问题来了,滚动条并没有到达底部,而是距离底部还有一点距离(一脸懵逼)估计是动态加载数据时,数据还未加载,滚动条就已经执行,知道原因了,那就实践呗。第二次尝试,利用vue的watch监控数据的改变,然后动态修改滚动条到顶部的距离代码实现:

```javascript

watch: {

'processData': 'scrollToBottom'

}

scrollToBottom: function () {

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

div.scrollTop = div.scrollHeight

}

```

再次崩溃了,好像没有毛用(陷入苦思)。这个时候我想到了$nextTick 。简单的介绍下$nextTick:Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新。$nextTick 是在下次 DOM 更新循环结束之后执行延迟回调,在修改数据之后使用 。既然$nextTick是在下次DOM更新时执行的,不正好符合我们的要求嘛(小激动)。代码实现:

```javascript

watch: {

'processData': 'scrollToBottom'

}

scrollToBottom: function () {

this.$nextTick(() => {

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

div.scrollTop = div.scrollHeight

})

}

```

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。