[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>
相关推荐
lxh01133 分钟前
最长公共子序列
前端·数据结构
Можно3 分钟前
ES6扩展运算符:从基础到实战的全方位解析
前端·javascript
豆苗学前端4 分钟前
闭包、现代JS架构的基石(吊打面试官)
前端·javascript·面试
雯0609~7 分钟前
uni-app:防止重复提交
前端·javascript·uni-app
爱吃大芒果8 分钟前
Flutter 自定义 Widget 开发:从基础绘制到复杂交互
开发语言·javascript·flutter·华为·ecmascript·交互
老华带你飞10 分钟前
健身房预约|基于springboot 健身房预约小程序系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·小程序
paopaokaka_luck11 分钟前
基于SpringBoot+Uniapp的自习室预约小程序(腾讯地图API、Echarts图形化分析、二维码识别)
vue.js·spring boot·后端·spring·echarts
2501_9181269111 分钟前
用html5写一个国际象棋
前端·javascript·css
遇见~未来15 分钟前
前端原生能力速查笔记(HTML + 浏览器 API 实战篇)
前端
2401_8603195218 分钟前
在React Native中开发一个轮播组件(Swipe轮播),通过组件react-native-snap-carousel来实现
javascript·react native·react.js