Vue实现渲染数据后控制滚动条位置(推荐)


Posted in Javascript onDecember 09, 2019

需求场景如下:

实现了消息发送,如果容器内消息过多,会出现滚动条,最新的消息位于最底部,不能及时出现在可视区域内,此时就需要在渲染列表后,将滚动条的位置定位到最底部。先来看看最终实现的效果

Vue实现渲染数据后控制滚动条位置(推荐)  

实现思路

  • 渲染完数据后,通过refs对象获取消息容器的实际高度
  • 将滚动条的设置到最底部

实现过程

sendMessage: function (event) {
  // 数据渲染
  this.senderMessageList.push(thisSenderMessageObj);
  // 改变滚动条位置
  this.messagesContainerTimer = setTimeout(()=>{
    this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight;
    console.log("当前滚动条位置:"+this.$refs.messagesContainer.scrollTop);
    console.log("当前可滚动区域容器的高度:"+this.$refs.messagesContainer.scrollHeight);
    // 清理定时器
    clearTimeout(this.messagesContainerTimer);
  },0);
}

踩坑记录

直接设置滚动条的位置

数据渲染完成后直接获取元素的真实高度,设置滚动条的位置,讲道理好像没什么毛病,结果滚动条的高度没有预想的渲染。问题原因:数据渲染完成后,Vue此时还没有渲染DOM元素,设置的滚动条高度还是之前的容器高度。

sendMessage: function (event) {
  // 数据渲染
  this.senderMessageList.push(thisSenderMessageObj);
  // 改变滚动条位置
  this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight;
  console.log("当前滚动条位置:"+this.$refs.messagesContainer.scrollTop);
  console.log("当前可滚动区域容器的高度:"+this.$refs.messagesContainer.scrollHeight);
}

Vue实现渲染数据后控制滚动条位置(推荐)

正确的改变方式: 使用setTimeout(),将DOM操作改为异步。

this.messagesContainerTimer = setTimeout(()=>{
  this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight;
  console.log("当前滚动条位置:"+this.$refs.messagesContainer.scrollTop);
  console.log("当前可滚动区域容器的高度:"+this.$refs.messagesContainer.scrollHeight);
  // 清理定时器
  clearTimeout(this.messagesContainerTimer);
},0);

总结

以上所述是小编给大家介绍的Vue实现渲染数据后控制滚动条位置,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
为jquery.ui.dialog 增加“在当前鼠标位置打开”的功能
Nov 24 Javascript
ExtJs3.0中Store添加 baseParams 的Bug
Mar 10 Javascript
json2.js的初步学习与了解
Oct 06 Javascript
js动画(animate)简单引擎代码示例
Dec 04 Javascript
JavaScript输入邮箱自动提示实例代码
Jan 13 Javascript
javascript打开word文档的方法
Apr 16 Javascript
jquery+html5时钟特效代码分享(可设置闹钟并且语音提醒)
Mar 30 Javascript
jQuery 3.0 的变化及使用方法
Feb 01 Javascript
Angular JS 生成动态二维码的方法
Feb 23 Javascript
详解vue-router 2.0 常用基础知识点之router.push()
May 10 Javascript
bootstrap switch开关组件使用方法详解
Aug 22 Javascript
详解jQuery中的easyui
Sep 02 jQuery
element-ui如何防止重复提交的方法步骤
Dec 09 #Javascript
js刷新页面location.reload()用法详解
Dec 09 #Javascript
vue 实现websocket发送消息并实时接收消息
Dec 09 #Javascript
Vue extend的基本用法(实例详解)
Dec 09 #Javascript
vue基于v-charts封装双向条形图的实现代码
Dec 09 #Javascript
微信小程序图片加载失败时替换为默认图片的方法
Dec 09 #Javascript
vue如何使用async、await实现同步请求
Dec 09 #Javascript
You might like
PHP4.04简明安装
2006/10/09 PHP
php基于base64解码图片与加密图片还原实例
2014/11/03 PHP
Linux(CentOS)下PHP扩展PDO编译安装的方法
2016/04/07 PHP
PHP 芝麻信用接入的注意事项
2016/12/01 PHP
swoole和websocket简单聊天室开发
2017/11/18 PHP
thinkPHP框架整合tcpdf插件操作示例
2018/08/07 PHP
javascript RadioButtonList获取选中值
2009/04/09 Javascript
AppBaseJs 类库 网上常用的javascript函数及其他js类库写的
2010/03/04 Javascript
JQuery的ready函数与JS的onload的区别详解
2013/11/21 Javascript
js实现鼠标滚轮控制图片缩放效果的方法
2015/02/20 Javascript
Javascript中的arguments与重载介绍
2015/03/15 Javascript
仅30行代码实现Javascript中的MVC
2016/02/15 Javascript
js获取时间函数及扩展函数的方法
2016/10/30 Javascript
JavaScript动态数量的文件上传控件
2016/11/18 Javascript
微信小程序 Template详解及简单实例
2017/01/05 Javascript
axios拦截设置和错误处理方法
2018/03/05 Javascript
iview实现图片上传功能
2020/06/29 Javascript
理解JavaScript中的Proxy 与 Reflection API
2020/09/21 Javascript
[29:59]完美世界DOTA2联赛PWL S3 Forest vs access 第二场 12.11
2020/12/13 DOTA
Python创建系统目录的方法
2015/03/11 Python
python字典快速保存于读取的方法
2018/03/23 Python
Tensorflow 训练自己的数据集将数据直接导入到内存
2018/06/19 Python
Python使用Shelve保存对象方法总结
2019/01/28 Python
python中property属性的介绍及其应用详解
2019/08/29 Python
Series和DataFrame使用简单入门
2019/11/13 Python
在Python中使用turtle绘制多个同心圆示例
2019/11/23 Python
Kendra Scott官网:美国领先的时尚配饰品牌
2020/10/22 全球购物
香港士多网上超级市场:Ztore
2021/01/09 全球购物
毕业班联欢会主持词
2014/03/27 职场文书
大学英语演讲稿范文
2014/04/24 职场文书
家长会标语
2014/06/24 职场文书
求职自我评价范文100字
2014/09/23 职场文书
正风肃纪查摆剖析材料
2014/10/10 职场文书
大学生实习介绍信
2015/05/05 职场文书
继承Win10缺点!教你关闭Win11烦人的网络搜索
2021/11/23 数码科技
Python OpenCV实现图形检测示例详解
2022/04/08 Python