当前位置: 移动技术网 > IT编程>脚本编程>vue.js > vue 中滚动条始终定位在底部的方法

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

2018年09月21日  | 移动技术网IT编程  | 我要评论

necps,张俊以简历,蔷薇公主之吻

滚动条定位在底部,首先想到的是,动态修改滚动条到顶部的距离等于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
 
}

再次崩溃了,好像没有毛用(陷入苦思)。

这个时候我想到了$nexttick 。

简单的介绍下$nexttick:

vue 实现响应式并不是数据发生变化之后 dom 立即变化,而是按一定的策略进行 dom 的更新。

$nexttick 是在下次 dom 更新循环结束之后执行延迟回调,在修改数据之后使用 。

既然$nexttick是在下次dom更新时执行的,不正好符合我们的要求嘛(小激动)。

代码实现:

watch: {
 
  'processdata': 'scrolltobottom'
 
}
 
scrolltobottom: function () {
 
  this.$nexttick(() => {
 
    var div = document.getelementbyid('data-list-content')
 
    div.scrolltop = div.scrollheight
 
  })
 
}

运行代码,成功了。

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网