Vue 3 中 onUnload 和 onPageScroll 使用详解

Vue 3 中 onUnload 和 onPageScroll 使用详解

在 Vue 3 中,当我们开发微信小程序时,通常需要处理页面生命周期事件和页面滚动事件,比如页面卸载 (onUnload) 和页面滚动 (onPageScroll) 等。这些功能对优化用户体验、实现动态效果以及处理页面状态管理至关重要。

本文将详细介绍如何在 Vue 3 中使用 onUnloadonPageScroll,包括语法糖的使用方式,并附加完整代码示例。


onUnload 生命周期事件

作用

onUnload 是微信小程序的页面生命周期事件,触发时机是页面卸载(离开当前页面,或者关闭页面)时。常见的应用场景包括:

  • 清理页面数据。
  • 停止未完成的请求。
  • 释放内存占用资源(如定时器、监听器等)。

使用方式

步骤
  1. Vue 3 的 onUnload 事件可以通过组合式 API 的 onUnmounted 来实现。
  2. 如果在特定页面中处理 onUnload,需要结合小程序的 PageComponent 的生命周期绑定事件。
代码示例

以下示例展示如何在 onUnload 中清理定时器:

vue 复制代码
<template>
  <view class="container">
    <text>{{ message }}</text>
  </view>
</template>

<script setup>
import { ref, onUnmounted } from 'vue';

const message = ref('正在加载数据...');
let timer;

function startTimer() {
  timer = setInterval(() => {
    console.log('计时器运行中...');
  }, 1000);
}

// 页面卸载时清理定时器
onUnmounted(() => {
  console.log('页面卸载,清理定时器');
  if (timer) {
    clearInterval(timer);
  }
});

// 初始化逻辑
startTimer();
</script>

<style scoped>
.container {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
}
</style>

onPageScroll 页面滚动事件

作用

onPageScroll 是微信小程序提供的页面滚动事件,触发时机为用户滚动页面时。常见的应用场景包括:

  • 实现滚动加载(如无限滚动)。
  • 根据滚动位置改变 UI(如动态导航栏)。
  • 滚动动画效果。

使用方式

步骤
  1. 在 Vue 3 中,通过 onPageScroll 钩子捕获滚动事件。
  2. onPageScroll 提供滚动位置信息,通过 scrollTop 获取滚动距离。
代码示例

以下示例实现滚动动态导航栏效果:

vue 复制代码
<template>
  <view class="page">
    <view :class="['navbar', { sticky: isSticky }]">导航栏</view>
    <scroll-view scroll-y="true" class="content">
      <view v-for="item in 50" :key="item" class="item">内容 {{ item }}</view>
    </scroll-view>
  </view>
</template>

<script setup>
import { ref, onMounted, onUnmounted } from 'vue';

const isSticky = ref(false);

// 监听滚动事件
function handleScroll({ scrollTop }) {
  isSticky.value = scrollTop > 100; // 滚动超过 100px 时固定导航栏
}

// 注册滚动事件
onMounted(() => {
  wx.onPageScroll(handleScroll);
});

// 卸载时移除滚动事件
onUnmounted(() => {
  wx.offPageScroll(handleScroll);
});
</script>

<style scoped>
.page {
  height: 100vh;
  overflow: hidden;
}
.navbar {
  width: 100%;
  height: 50px;
  line-height: 50px;
  text-align: center;
  background-color: #eee;
  transition: all 0.3s;
}
.navbar.sticky {
  background-color: #333;
  color: #fff;
}
.content {
  height: calc(100vh - 50px);
  overflow-y: scroll;
}
.item {
  height: 50px;
  line-height: 50px;
  text-align: center;
  border-bottom: 1px solid #ddd;
}
</style>

更多相关知识点

Vue 3 小程序支持的常见生命周期

除了 onUnloadonPageScroll,小程序开发中常用的生命周期事件包括:

  • onLoad: 页面加载时触发。
  • onShow: 页面显示时触发。
  • onHide: 页面隐藏时触发。
  • onReady: 页面初次渲染完成时触发。

事件绑定的注意事项

  1. 性能优化
    对于频繁触发的事件(如 onPageScroll),建议对事件进行节流或防抖处理。
  2. 清理资源
    onUnload 或其他生命周期结束时,应清理占用的资源(如事件监听器、定时器等),以避免内存泄漏。

总结

通过本文的学习,我们了解了如何在 Vue 3 开发的微信小程序中使用 onUnloadonPageScroll,并掌握了相关的注意事项和优化技巧。结合语法糖形式,可以让代码更加清晰简洁。

相关推荐
边洛洛29 分钟前
路由传参、搜索、多选框勾选、新增/编辑表单复用
前端·javascript·vue.js
breakthrough_011 小时前
创建一个简单的 Nuxt.js 应用
开发语言·javascript·ecmascript
秋田君3 小时前
uniapp中使用Mescroll实现下拉刷新与上拉加载项目实战
javascript·uni-app
川石教育3 小时前
Vue前端开发-slot传参
前端·vue.js·前端框架·前端开发·slot组件
确实菜,真的爱3 小时前
vue3 element plus 把表格数据导出到excel
javascript·vue.js·excel
一舍予4 小时前
nuxt3项目搭建相关
开发语言·javascript·vue.js·nuxt
新时代的弩力4 小时前
【Cesium】--viewer,entity,dataSource
前端·javascript·vue.js
无恃而安4 小时前
localStorage缓存 接口 配置
javascript·vue.js·缓存
余道各努力,千里自同风4 小时前
HTML5 视频 Vedio 标签详解
前端·音视频·html5