[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>
相关推荐
CodeClimb8 分钟前
【华为OD-E卷-木板 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
咸鱼翻面儿12 分钟前
Javascript异步,这次我真弄懂了!!!
javascript
brrdg_sefg13 分钟前
Rust 在前端基建中的使用
前端·rust·状态模式
m0_7482309437 分钟前
Rust赋能前端: 纯血前端将 Table 导出 Excel
前端·rust·excel
qq_589568101 小时前
Echarts的高级使用,动画,交互api
前端·javascript·echarts
黑客老陈2 小时前
新手小白如何挖掘cnvd通用漏洞之存储xss漏洞(利用xss钓鱼)
运维·服务器·前端·网络·安全·web3·xss
正小安2 小时前
Vite系列课程 | 11. Vite 配置文件中 CSS 配置(Modules 模块化篇)
前端·vite
编程百晓君2 小时前
一文解释清楚OpenHarmony面向全场景的分布式操作系统
vue.js
暴富的Tdy2 小时前
【CryptoJS库AES加密】
前端·javascript·vue.js