vue实现动态添加数据滚动条自动滚动到底部的示例代码


Posted in Javascript onJuly 06, 2018

在使用vue实现聊天页面的时候,聊天数据动态加到页面中,需要实现滚动条也自动滚动到底部。这时我找到网上有个插件 vue-chat-scroll

https://www.npmjs.com/package/vue-chat-scroll

但是安装后发现是用不了的,报错信息如下:

VM14383:27 [Vue warn]: Failed to resolve directive: chat-scroll
(found in <Hello>)

这个一直找不到原因,可能是我vue的版本是2.2不支持吧。。。后来找到一个解决办法:

添加watch方法,监听数据变量的变化,动态添加滚动条,一开始我代码如下:

watch: {
  chatlog() {
    var container = this.$el.querySelector("#chatContainer");
    console.log(container);
    container.scrollTop = container.scrollHeight;
   }
 }

但是发现滚动条都是滚动到倒数第二条数据上,所以需要如下代码来解决:

watch: {
  chatlog() {
   console.log("chatlog change");
   this.$nextTick(() => {
    var container = this.$el.querySelector("#chatContainer");
    console.log(container);
    container.scrollTop = container.scrollHeight;
   })
   // document.getElementById('chatContainer').scrollTop = document.getElementById('chatContainer').scrollHeight+150;

  }
 }

相应在ul中添加一个id属性为chatContainer

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
在线编辑器的实现原理(兼容IE和FireFox)
Mar 09 Javascript
直接生成打开窗口代码,不必下载
May 14 Javascript
微信公众号-获取用户信息(网页授权获取)实现步骤
Oct 21 Javascript
解决vue-router进行build无法正常显示路由页面的问题
Mar 06 Javascript
bootstrap table合并行数据并居中对齐效果
Oct 17 Javascript
微信小程序下拉刷新PullDownRefresh的使用方法
Nov 29 Javascript
JavaScript函数的4种调用方法实例分析
Mar 05 Javascript
node(koa2) web应用模块介绍详解
Mar 29 Javascript
JS实现移动端在线签协议功能
Aug 22 Javascript
微信小程序之下拉列表实现方法解析(附完整源码)
Aug 23 Javascript
Vue解析带html标签的字符串为dom的实例
Nov 13 Javascript
微信小程序scroll-view不能左右滑动问题的解决方法
Jul 09 Javascript
微信小程序利用canvas 绘制幸运大转盘功能
Jul 06 #Javascript
用Node提供静态文件服务的方法
Jul 06 #Javascript
vue使用监听实现全选反选功能
Jul 06 #Javascript
vue 实现数字滚动增加效果的实例代码
Jul 06 #Javascript
详解在Vue中使用TypeScript的一些思考(实践)
Jul 06 #Javascript
javascript显示动态时间的方法汇总
Jul 06 #Javascript
Django+Vue跨域环境配置详解
Jul 06 #Javascript
You might like
php记录代码执行时间(实现代码)
2013/07/05 PHP
php后台如何避免用户直接进入方法实例
2013/10/15 PHP
PHP开源开发框架ZendFramework使用中常见问题说明及解决方案
2014/06/12 PHP
PHP如何通过AJAX方式实现登录功能
2015/11/23 PHP
php实现搜索类封装示例
2016/03/31 PHP
laravel 框架结合关联查询 when()用法分析
2019/11/22 PHP
发布BlueShow v1.0 图片浏览器(类似lightbox)blueshow.js 打包下载
2007/07/21 Javascript
JQuery.uploadify 上传文件插件的使用详解 for ASP.NET
2010/01/22 Javascript
ExtJs Excel导出并下载IIS服务器端遇到的问题
2011/09/16 Javascript
js编码、解码函数介绍及其使用示例
2013/09/05 Javascript
Extjs的FileUploadField文件上传出现了两个上传按钮
2014/04/29 Javascript
多引号嵌套的变量命名的问题
2014/05/09 Javascript
jQuery实现统计复选框选中数量
2014/11/24 Javascript
跟我学习javascript的作用域与作用域链
2015/11/19 Javascript
基于Jquery实现仿百度百科右侧导航代码附源码下载
2015/11/27 Javascript
Vue.js 表单校验插件
2016/08/14 Javascript
jQuery 获取select选中值及清除选中状态
2016/12/13 Javascript
vue数据双向绑定的注意点
2017/06/23 Javascript
跟老齐学Python之编写类之四再论继承
2014/10/11 Python
Python中if __name__ == &quot;__main__&quot;详细解释
2014/10/21 Python
简单的python后台管理程序
2017/04/13 Python
PyQt5实现无边框窗口的标题拖动和窗口缩放
2018/04/19 Python
Django实现跨域请求过程详解
2019/07/25 Python
Python循环实现n的全排列功能
2019/09/16 Python
马来西亚航空官方网站:Malaysia Airlines
2017/07/28 全球购物
澳大利亚Mocha官方网站:包、钱包、珠宝和配饰
2019/07/18 全球购物
澳洲Chemist Direct药房中文网:澳洲大型线上直邮药房
2019/11/04 全球购物
日本酒店、民宿、温泉旅馆、当地旅行团中文预订:e路东瀛
2019/12/09 全球购物
小学红领巾中秋节广播稿
2014/01/13 职场文书
浪费资源的建议书
2014/03/12 职场文书
学校师德承诺书
2014/05/23 职场文书
党员民主生活会材料
2014/12/15 职场文书
护士年终考核评语
2014/12/31 职场文书
学习雷锋主题班会
2015/08/14 职场文书
红灯733-1型14管5波段半导体收音机
2021/04/22 无线电
golang中的struct操作
2021/11/11 Golang