Vue如何设置滚动条自动保持到最底端
更新时间:2024年08月13日 11:41:20 作者:Lipn
在开发中我们常常会遇到需要让滚动条保持到最底端的需求,比如在开发一个聊天框时,请求接口拿到消息列表数据,展示到前端页面时,需要让滚动条自动滚到最底端,以此来展示最后的聊天记录,这篇文章主要介绍了Vue如何设置滚动条自动保持到最底端,需要的朋友可以参考下
Vue设置滚动条自动保持到最底端
需求描述:在开发中我们常常会遇到需要让滚动条保持到最底端的需求,比如在开发一个聊天框时,请求接口拿到消息列表数据,展示到前端页面时,需要让滚动条自动滚到最底端,以此来展示最后的聊天记录。同时,当发送一条新的消息时,也需要滚动条自动滚动到最底端,默认显示到最后一条数据,而不是在发送完一条新消息之后还需要手动滑动滚动条到最底端。
主要实现原理:
其实这个需求就是需要设置该元素(产生滚动条的元素)的scrollTop 等于scrollHeight
主要代码:
<template>
<div ref="box" class="box"></div>
</template>
<script>
// 滚动到底部
scrollToBottom() {
// 这里是Vue2的写法
const box = this.$refs.box as HTMLElement
this.$nextTick(() => {
box.scrollTop = box.scrollHeight
})
}
</script>
<style>
.box {
overflow: auto;
height: 446px; /*重要!一定要有高度才会生成滚动条*/
}
</style>
注意事项:
box容器必须设置具体的高度height,否则不会产生滚动条,(如果页面上看有滚动条,那可能是父元素产生的滚动条),如果没有给box容器设置高度的话,这个scrollToBottom方法就不会生效!
补充:Vue项目中让滚动条始终处于最底部
Vue项目中让滚动条始终处于最底部
效果图:

核心代码:
// 让滚动条始终在最底部
this.$nextTick(() => {
this.$refs.messageContent.scrollTop = this.$refs.messageContent.scrollHeight
})
到此这篇关于Vue如何设置滚动条自动保持到最底端的文章就介绍到这了,更多相关Vue滚动条自动保持到最底端内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
使用vscode 开发uniapp的方法
本文给大家分享我使用vscode开发的一些配置。其中包括uniapp组件语法提示,uniapp代码提示,代码自动格式化问题,对vscode 开发uniapp的相关知识感兴趣的朋友一起看看吧
2021-08-08
vue 请求后端数据的示例代码
在vue中,我们如何通过请求接口来访问后端的数据呢?在这里简单总结了一个小示例,对vue请求后端数据实例代码感兴趣的朋友一起看看吧
2022-09-09
vue制作加载更多功能的正确打开方式
这篇文章是一篇Vue.js的教程,目标在于用一种常见的业务场景——分页/无限加载,以及编写过程中自己的错误写法,分享给大家,帮助读者更好的理解Vue.js中的一些设计思想。
2016-10-10
vue的axios和mock.js你了解吗
这篇文章主要为大家详细介绍了vue的axios和mock.js,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
2022-02-02
vue项目登录模块滑块拼图验证功能实现代码(纯前端)
滑块验证作为一种反机器人的工具,也会不断发展和演进,以适应不断变化的威胁,这篇文章主要给大家介绍了vue项目登录模块滑块拼图验证功能实现的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
2024-07-07
vue3保存属性自动换行问题及解决
这篇文章主要介绍了vue3保存属性自动换行问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
2024-03-03
vue悬浮可拖拽悬浮按钮的实例代码
这篇文章主要介绍了vue悬浮可拖拽悬浮按钮的实例代码,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
2019-08-08
el-date-picker默认结束为当前时分秒的操作方法
在element ui中的日期时间选择组件中默认是00:00,现在需求是点击默认结束时间为当前时分秒,查了很多资料写的都不准确 ,今天给大家分享el-date-picker默认结束为当前时分秒的操作方法,感兴趣的朋友一起看看吧
2024-01-01
最新评论