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 相关文章推荐
js下用gb2312编码解码实现方法
Dec 31 Javascript
加速IE的Javascript document输出的方法
Dec 02 Javascript
jQuery EasyUI API 中文文档 - TreeGrid 树表格使用介绍
Nov 21 Javascript
使用jQuery清空file文件域的解决方案
Apr 12 Javascript
JS选取DOM元素的简单方法
Jul 08 Javascript
AngularJS Ajax详解及示例代码
Aug 17 Javascript
JavaScript 判断一个对象{}是否为空对象的简单方法
Oct 09 Javascript
详解Vue 非父子组件通信方法(非Vuex)
May 24 Javascript
vue双向数据绑定知识点总结
Apr 18 Javascript
原生JS forEach()和map()遍历的区别、兼容写法及jQuery $.each、$.map遍历操作
Feb 27 jQuery
JS实现分页导航效果
Feb 19 Javascript
基于Electron实现桌面应用开发代码实例
Jul 07 Javascript
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
索尼SONY ICF-7600A(W)电路分析
2021/03/01 无线电
CentOS6.5 编译安装lnmp环境
2014/12/21 PHP
PHP经典设计模式之依赖注入定义与用法详解
2019/05/21 PHP
基于Laravel-admin 后台的自定义页面用法详解
2019/09/30 PHP
用JavaScript实现UrlEncode和UrlDecode的脚本代码
2008/07/23 Javascript
使用jQuery实现dropdownlist的联动效果(sharepoint 2007)
2011/03/30 Javascript
js之onload事件的一点使用心得
2013/08/14 Javascript
js在输入框屏蔽按键,只能键入数字的示例代码
2014/01/03 Javascript
jQuery打印指定区域Html页面并自动分页
2014/07/04 Javascript
JS 使用for循环遍历子节点查找元素
2014/09/06 Javascript
node.js中的http.response.writeHead方法使用说明
2014/12/14 Javascript
JS使用ajax方法获取指定url的head信息中指定字段值的方法
2015/03/24 Javascript
js实现简单选项卡与自动切换效果的方法
2015/04/10 Javascript
js实现表单及时验证功能 用户信息立即验证
2016/09/13 Javascript
NODE.JS跨域问题的完美解决方案
2016/10/20 Javascript
vue.js实现价格格式化的方法
2017/05/23 Javascript
原生JS实现隐藏显示图片 JS实现点击切换图片效果
2021/01/27 Javascript
浅谈express 中间件机制及实现原理
2017/08/31 Javascript
JavaScript实现轮播图效果代码实例
2019/09/28 Javascript
python读写ini配置文件方法实例分析
2015/06/30 Python
Python实现包含min函数的栈
2016/04/29 Python
python3.5+tesseract+adb实现西瓜视频或头脑王者辅助答题
2018/01/17 Python
python 在指定范围内随机生成不重复的n个数实例
2019/01/28 Python
Python socket模块实现的udp通信功能示例
2019/04/10 Python
Pycharm2020.1安装无法启动问题即设置中文插件的方法
2020/08/07 Python
python+requests接口自动化框架的实现
2020/08/31 Python
BIBLOO捷克:购买女装、男装、童装、鞋和配件
2017/01/27 全球购物
Myprotein瑞典官方网站:畅销欧洲英国运动营养品牌
2018/01/22 全球购物
Currentbody美国/加拿大:美容仪专家
2020/03/09 全球购物
工作时间上网检讨书
2014/02/03 职场文书
少年闰土教学反思
2014/02/22 职场文书
环保志愿者活动总结
2014/06/27 职场文书
小学教师个人总结
2015/02/05 职场文书
主持人开场白台词
2015/05/29 职场文书
幼儿园中班教学反思
2016/03/03 职场文书
PHP获取学生成绩的方法
2021/11/17 PHP