当前位置: 首页 > article >正文

UniAPP和Vue3生命周期hook

Uni-app 是一个使用 Vue.js 开发跨平台应用的框架,支持编译到多个平台(如 iOS、Android、H5、微信小程序等)。在 Uni-app 中,生命周期钩子(Lifecycle Hooks)用于在应用或页面的不同阶段执行特定的逻辑。理解和合理使用生命周期钩子,有助于优化应用的性能和用户体验。

一、应用(App)级生命周期钩子

这些钩子函数用于整个应用的生命周期管理,主要在 App.vue 文件中定义。

生命周期钩子触发时机说明
onLaunch应用初始化时触发,只会触发一次用于进行初始化操作,如获取全局数据、进行登录等
onShow应用启动,或从后台切回前台时触发适用于刷新数据或恢复应用状态
onHide应用切到后台时触发适用于保存应用状态、停止计时器等
onError应用发生脚本错误时触发用于错误日志收集和处理
onPageNotFound当打开的页面不存在时触发可以进行页面重定向或提示用户

示例:App.vue 中定义生命周期钩子

export default {
  onLaunch(options) {
    console.log('应用启动', options);
    // 初始化操作
  },
  onShow(options) {
    console.log('应用显示', options);
    // 恢复应用状态
  },
  onHide() {
    console.log('应用隐藏');
    // 保存应用状态
  },
  onError(error) {
    console.error('应用错误', error);
    // 错误处理
  },
  onPageNotFound(err) {
    console.warn('页面未找到', err);
    // 页面重定向
  }
}

二、页面级生命周期钩子

每个页面都有自己的生命周期钩子,用于管理页面在不同阶段的行为。这些钩子在页面的 .vue 文件中定义。

生命周期钩子触发时机说明
onLoad页面加载时触发接收路由参数,进行初始化
onShow页面显示时触发页面从后台或其他页面返回时调用
onReady页面初次渲染完成时触发适合进行与视图相关的操作
onHide页面隐藏时触发跳转到其他页面或应用进入后台
onUnload页面卸载时触发页面销毁前的清理操作
onPullDownRefresh用户下拉刷新时触发实现下拉刷新功能
onReachBottom页面滚动到底部时触发加载更多数据
onShareAppMessage用户点击分享时触发定制分享内容
onShareTimeline用户分享到朋友圈时触发定制分享到朋友圈的内容

示例:页面中的生命周期钩子

export default {
  data() {
    return {
      // 页面数据
    }
  },
  onLoad(options) {
    console.log('页面加载', options);
    // 初始化数据
  },
  onShow() {
    console.log('页面显示');
    // 刷新数据
  },
  onReady() {
    console.log('页面初次渲染完成');
    // 与视图相关的操作
  },
  onHide() {
    console.log('页面隐藏');
    // 保存页面状态
  },
  onUnload() {
    console.log('页面卸载');
    // 清理资源
  },
  onPullDownRefresh() {
    console.log('用户下拉刷新');
    // 刷新数据
    uni.stopPullDownRefresh(); // 停止下拉刷新
  },
  onReachBottom() {
    console.log('页面滚动到底部');
    // 加载更多数据
  },
  onShareAppMessage() {
    return {
      title: '分享标题',
      path: '/pages/home/home',
      imageUrl: '/static/share.png'
    };
  },
  onShareTimeline() {
    return {
      title: '分享到朋友圈的标题'
    };
  }
}

三、组件级生命周期钩子

在 Uni-app 中,组件也有自己的生命周期钩子,类似于 Vue.js 的生命周期钩子。这些钩子用于管理组件的创建、更新和销毁过程。

生命周期钩子触发时机说明
created组件实例创建后触发数据初始化等操作
mounted组件挂载到页面后触发DOM 操作等
updated组件数据更新后触发响应数据变化
destroyed组件销毁前触发清理资源

示例:组件中的生命周期钩子

export default {
  data() {
    return {
      // 组件数据
    }
  },
  created() {
    console.log('组件创建');
    // 初始化数据
  },
  mounted() {
    console.log('组件挂载');
    // 访问 DOM
  },
  updated() {
    console.log('组件更新');
    // 响应数据变化
  },
  destroyed() {
    console.log('组件销毁');
    // 清理定时器等资源
  }
}

四、注意事项

  1. 区分 App 和页面生命周期钩子:确保在正确的位置使用相应的生命周期钩子,如应用级钩子在 App.vue,页面级钩子在页面组件中。
  2. 异步操作:在生命周期钩子中进行异步操作(如网络请求)时,注意处理好回调和错误,避免阻塞页面渲染。
  3. 性能优化:合理利用生命周期钩子进行数据加载和资源管理,避免在频繁触发的钩子中执行重操作,如 onShowonHide

五、参考资料

  • Uni-app 官方文档 - 生命周期
  • Vue.js 官方文档 - 生命周期钩子

http://www.kler.cn/a/488456.html

相关文章:

  • FFmpeg Muxer HLS
  • 计算机网络 笔记 数据链路层 2
  • 1. Doris分布式环境搭建
  • 深入理解 C 语言中浮点型数据在内存中的存储
  • 30天开发操作系统 第 12 天 -- 定时器 v1.0
  • Angular生命周期
  • 【计算机网络】课程 实验二 交换机基本配置和VLAN 间路由实现
  • mysql和redis的最大连接数
  • Linux之线程池与单例模式
  • GPT-1模型详解及代码复现
  • 利用Python爬虫获取义乌购店铺所有商品列表:技术探索与实践
  • 开启Excel导航仪,跨表跳转不迷路-Excel易用宝
  • IntelliJ IDEA中Maven项目的配置、创建与导入全攻略
  • windows C#-泛型类型参数的约束详解(一)
  • 算法-盒子中小球的最大数量
  • C16.【C++ Cont】string类字符串的关系运算和与string有关的函数
  • JavaScript系列(10)-- Map数据结构专题
  • 如何确保获取的淘宝详情页数据的准确性和时效性?
  • 基于Ubuntu2404脚本搭建openstackC版-ovn网络驱动
  • 设计模式 创建型 抽象工厂模式(Abstract Factory)与 常见技术框架应用 解析
  • Win32汇编学习笔记06.APIHook
  • 单片机 期末笔记
  • 《探秘鸿蒙NEXT中的人工智能核心架构》
  • 【2025 Rust学习 --- 11 实用工具特型01】
  • 车载音频开发(二):对音频数据作音量调节
  • Java 基于微信小程序的高校科研团队管理系统设计与实现(附源码,部署,文档