[Vue3] 滚动条自动滚动到底部

需求

在一个区域会依次打印log,随着log的加长,出现滚动条,而滚动条应该始终保持在最下方。

点击回到顶部按钮,可以使滚动条回到最上方

方案

  1. 在滚动区域添加ref
  2. log为一个数组,对其添加watch
  3. 在watch函数中,使用nextTick,通过ref控制该区域滚动高度
  4. 绑定ref,监测其height,使回到顶部按钮出现,并通过ref控制滚动条回到顶部

代码

javascript 复制代码
// template
<div class="bottom-logs" ref="logRef">
	// antd vue中的back-top组件
	<a-back-top :target="() => logRef" :visibilityHeight="10" @click="handleBackToTop" />
    <LogData :logData="log"></LogData>
</div>

// css
// 父级元素 display: flex
.bottom-logs {
  flex: 1;
  overflow: auto;
}
javascript 复制代码
<script setup>
import { ref, watch, nextTick } from 'vue'
const logRef = ref();
// log为响应式数组
watch(log, () => {
  nextTick(() => {
    const content = logRef.value;
    content.scrollTo({ top: content.scrollHeight, behavior: "smooth" });
  });
}, {
  deep: true,
});

const handleBackToTop = () => {
  const content = logRef.value;
  content.scrollTo({ top: 0, behavior: "smooth" });
}
</script>
相关推荐
续亮~33 分钟前
6、Redis系统-数据结构-05-整数
java·前端·数据结构·redis·算法
顶顶年华正版软件官方2 小时前
剪辑抽帧技巧有哪些 剪辑抽帧怎么做视频 剪辑抽帧补帧怎么操作 剪辑抽帧有什么用 视频剪辑哪个软件好用在哪里学
前端·音视频·视频·会声会影·视频剪辑软件·视频剪辑教程·剪辑抽帧技巧
MarkHD3 小时前
javascript 常见设计模式
开发语言·javascript·设计模式
程序员云翼3 小时前
7-理财平台
java·vue.js·spring boot·后端·毕设
托尼沙滩裤3 小时前
【js面试题】js的数据结构
前端·javascript·数据结构
不熬夜的臭宝3 小时前
每天10个vue面试题(一)
前端·vue.js·面试
朝阳393 小时前
vue3【实战】来回拖拽放置图片
javascript·vue.js
不如喫茶去3 小时前
VUE自定义新增、复制、删除dom元素
前端·javascript·vue.js
长而不宰4 小时前
vue3+electron项目搭建,遇到的坑
前端·vue.js·electron
阿垚啊4 小时前
vue事件参数
前端·javascript·vue.js