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滚动条自动保持到最底端内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决在Vue中使用axios POST请求变成OPTIONS的问题
这篇文章主要介绍了解决在Vue中使用axios POST请求变成OPTIONS的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-08-08vue之使用echarts图表setOption多次很卡问题及解决
这篇文章主要介绍了vue之使用echarts图表setOption多次很卡问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-07-07如何使用Vue mapState快捷获取Vuex state多个值
这篇文章主要为大家介绍了如何使用Vue mapState快捷获取Vuex state多个值实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-06-06
最新评论