Vue设置滚动条自动保持到最底端

需求描述:在开发中我们常常会遇到需要让滚动条保持到最底端的需求,比如在开发一个聊天框时,请求接口拿到消息列表数据,展示到前端页面时,需要让滚动条自动滚到最底端,以此来展示最后的聊天记录。同时,当发送一条新的消息时,也需要滚动条自动滚动到最底端,默认显示到最后一条数据,而不是在发送完一条新消息之后还需要手动滑动滚动条到最底端。

主要实现原理:

其实这个需求就是需要设置该元素(产生滚动条的元素)的scrollTop 等于scrollHeight

主要代码:

html 复制代码
<template>
	<div ref="box" class="box"></div>
</template>
html 复制代码
<script>
	// 滚动到底部
	scrollToBottom() {
	  // 这里是Vue2的写法
	  const box = this.$refs.box as HTMLElement
	  this.$nextTick(() => {
	    box.scrollTop = box.scrollHeight
	  })
	}
</script>
html 复制代码
<style>
.box {
	overflow: auto;
	height: 446px;  /*重要!一定要有高度才会生成滚动条*/
 }
 </style>

注意事项:

box容器必须设置具体的高度height,否则不会产生滚动条,(如果页面上看有滚动条,那可能是父元素产生的滚动条),如果没有给box容器设置高度的话,这个scrollToBottom方法就不会生效!

如果本篇博客对你有帮助,请点个赞吧o( ̄▽ ̄)d

相关推荐
wuxia211821 小时前
Web全栈开发案例教程(AI辅助版)
前端
MonkeyKing715521 小时前
Flutter Riverpod 2.x 设计思想与最佳实践
前端·flutter
tzy23321 小时前
梳理一下前端模块化规范:CommonJS ESM AMD CMD UMD
前端·webpack·cmd·commonjs·amd·esm·umd
jerrywus1 天前
别再陪 AI 调 iOS 了:用 cmux + baguette,让 Claude 在你的模拟器里"自己动手"
前端·ios·claude
文心快码BaiduComate1 天前
Comate Spec模式实践:电商视频自动化生产数据库eDB-MCP服务开发
前端·后端·架构
page_qiu1 天前
高并发&大数据量&毫秒级响应系统设计方案
java·前端·数据库·高并发·高响应
皮皮大人1 天前
agent设计系统-大模型意图识别
前端·人工智能
三维搬砖者1 天前
挑战AI辅助从零构建3D模型编辑器:01基于Vue3 + Three.js的现代化架构设计
前端·vue.js·github
GinoWi1 天前
Python 集合
前端·python
时光足迹1 天前
Tiptap之标注组件
前端·javascript·react.js