一文详解vue生命周期在uniapp中的用法

 更新时间:2024年01月22日 09:15:14   作者:沐渃清澄  
在uniapp中,vue的生命周期的用法基本都得以保留,但是对于特殊的需求以及特殊的情况,uniapp还引入了一些特有的生命周期钩子,本文给大家详细介绍了vue生命周期在uniapp中的用法,感兴趣的朋友可以参考下

前言

首先我们要了解什么是uniappuni-app是一种基于 Vue.js 的跨平台应用框架,可以帮助开发者使用一套代码同时构建小程序、H5、APP等多个平台的应用。 以下是 uni-app 的一些关键特性和概念:

  • 跨平台开发: uni-app 支持同时开发微信小程序、支付宝小程序、百度小程序、H5、APP 等多个平台,通过一套代码实现多端运行。
  • 基于 Vue.js: uni-app 基于 Vue.js 框架,开发者可以使用熟悉的 Vue.js 语法进行开发,同时享受 Vue.js 生态系统的丰富资源。
  • 统一组件和 API: uni-app 提供了一套统一的组件和 API,开发者可以在不同平台上使用相同的组件和接口,减少了因平台差异而引起的代码调整。
  • 自定义组件和插件: 开发者可以通过创建自定义组件和插件来扩展 uni-app 的功能,实现更多定制化的需求。
  • 支持原生能力: uni-app 提供了一些内置的原生能力,例如拍照、录音、获取地理位置等,同时也支持调用原生小程序和原生 APP 的接口。
  • 运行时性能优化: uni-app 通过将模板编译为原生渲染的方式,优化了运行时性能,提高了应用的响应速度。
  • 开发工具支持: uni-app 提供了开发工具,包括 HBuilderX等,用于辅助开发和调试。
  • 生态系统: uni-app 生态系统丰富,有大量社区贡献的插件、模板和组件,方便开发者快速搭建和部署应用。

uniapp中的vue生命周期

uniapp中,vue的生命周期的用法基本都得以保留,但是对于特殊的需求以及特殊的情况,uniapp还引入了一些特有的生命周期钩子。如下面的例子:

1、基本的生命周期

uni-app 中,我们可以正常使用 vue 生命周期的常见钩子,例如 createdmountedupdateddestroyed

<template>
  <view>
    <p>{{ message }}</p>
  </view>
</template>

<script>
export default {
  data() {
    return {
      message: 'Hello, uni-app!'
    };
  },
  created() {
    console.log('vue created ');
  },
  mounted() {
    console.log('vue mounted ');
  },
  updated() {
    console.log('vue updated ');
  },
  destroyed() {
    console.log('vue destroyed ');
  }
}
// 输出结果为:
// vue created
// vue mounted
// vue updated
// vue destroyed
</script>

uniapp中,created 生命周期在组件实例创建后被调用,mounted 生命周期在组件挂载到 DOM 后被调用。updated 生命周期会在数据更新导致重新渲染时调用。destroyed 生命周期在组件销毁时被调用。

2、特有的生命周期钩子

uniapp 引入了一些特有的生命周期钩子,可以用于处理特定平台的需求。以下是一些示例:

  • onNavigationBarButtonTap:处理小程序端导航栏按钮点击事件。如:
<script>
export default {
  methods: {
    onNavigationBarButtonTap() {
      console.log('Button');
    }
  }
}
</script>

onNavigationBarButtonTap 生命周期钩子用于处理小程序端导航栏按钮点击事件。当用户点击导航栏按钮时,此函数会被触发。

onLaunchonHideonError:处理 APP 端的启动、进入后台和错误等情况。

<script>
export default {
  onLaunch(options) {
    console.log('Launched', options);
  },
  onHide() {
    console.log('Hidden');
  },
  onError(err) {
    console.error('Error', err);
  }
}
</script>

在上述三个生命周期钩子中,onLaunchonError是会携带一个参数的,其中options,包含了 APP 启动时的参数信息,err,包含了错误信息。

3、页面生命周期

uniapp 的页面生命周期在不同平台中也有所不同,如小程序端的 onLoadonReady

<script>
export default {
  onLoad(options) {
    console.log('Loaded', options);
  },
  onReady() {
    console.log('Ready');
  }
}
</script>

uniapp 中,onLoad 生命周期在页面加载时被调用,onReady 生命周期在页面渲染完成后被调用。onLoad 会接收页面参数 options,包含了页面的启动参数。

结语

总的来说,vue生命周期在uniapp中有了如下的变化:

  • 生命周期的执行顺序:uniapp 中,生命周期的执行顺序与 Vue.js 的标准执行顺序基本相同,但部分生命周期在小程序和APP端的执行时机有所不同。

    • 小程序端:onLoad -> onShow -> onReady -> onHide -> onUnload
    • APP端:onLaunch -> onShow -> onHide -> onError
  • 特有生命周期钩子: uni-app 引入了一些特有的生命周期钩子,例如 onNavigationBarButtonTaponBackPressonPageScroll 等,用于处理在不同端(小程序、APP等)的特定事件。

  • onReady 在小程序端: onReady 生命周期在小程序端表示页面渲染完成,而在 Vue.js 中 mounted 生命周期表示 DOM 渲染完成。在 uni-app 中,你可能需要在 onReady 钩子中进行一些 DOM 操作。

  • APP端生命周期:uni-app 的 APP 端,引入了额外的生命周期钩子,如 onLaunchonHideonError。这些生命周期用于处理 APP 启动、进入后台和错误等情况。

  • beforeDestroy 在APP端:uni-app 的 APP 端,beforeDestroy 生命周期用于监听 APP 生命周期的销毁情况,这在 Vue.js 中是没有的。

  • Vue.js 生命周期相同: 除了上述变化,uni-app 中依然保留了 Vue.js 标准的生命周期钩子,如 createdmountedupdateddestroyed

以上就是一文详解vue生命周期在uniapp中的用法的详细内容,更多关于vue生命周期在uniapp中的用法的资料请关注脚本之家其它相关文章!

相关文章

  • vue中使用Echarts map图实现下钻至县级的思路详解

    vue中使用Echarts map图实现下钻至县级的思路详解

    这篇文章主要介绍了vue中使用Echarts map图实现下钻至县级,需要注意的是,因为我是直接从 vue-cli2 直接跳到 vue-cli4 ,还奇怪怎么读取不到JSON,查找后才知道 vue-cli3 往后的项目基础架构对比旧版本有些区别,感兴趣的朋友跟随小编一起看看吧
    2022-01-01
  • Vue开发Sort组件代码详解

    Vue开发Sort组件代码详解

    这篇文章主要介绍了Vue开发Sort组件,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2021-10-10
  • 全局安装 Vue cli3 和 继续使用 Vue-cli2.x操作

    全局安装 Vue cli3 和 继续使用 Vue-cli2.x操作

    这篇文章主要介绍了全局安装 Vue cli3 和 继续使用 Vue-cli2.x操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • vue实现用户长时间不操作自动退出登录功能的实现代码

    vue实现用户长时间不操作自动退出登录功能的实现代码

    这篇文章主要介绍了vue实现用户长时间不操作自动退出登录功能的实现代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • Vue3的路由守卫以及登录状态储存过程

    Vue3的路由守卫以及登录状态储存过程

    这篇文章主要介绍了Vue3的路由守卫以及登录状态储存过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • vue3+TS reactive设定类型方式

    vue3+TS reactive设定类型方式

    这篇文章主要介绍了vue3+TS reactive设定类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • Vue两个版本的区别和使用方法(更深层次了解)

    Vue两个版本的区别和使用方法(更深层次了解)

    在我们使用 vue时,我们可以引用两个不同版本的 Vue,分别是 Vue完整版(vue.js)和 Vue(vue.runtime.js )非完整版,那么它们的区别是什么呢,今天我们就来分析下这两个不同版本之间的区别,一起看看吧
    2020-02-02
  • Vue Element校验validate的实例

    Vue Element校验validate的实例

    这篇文章主要介绍了Vue Element校验validate的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Vue对Element中el-tab-pane添加@click事件无效问题解决

    Vue对Element中el-tab-pane添加@click事件无效问题解决

    这篇文章主要给大家介绍了关于Vue对Element中el-tab-pane添加@click事件无效问题的解决办法,文中通过图文以及代码示例介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • 前端uniapp微信小程序跨域问题的解决方法

    前端uniapp微信小程序跨域问题的解决方法

    跨域指的是在浏览器中,当一个网页尝试加载另一个不同域名(或协议、端口号)下的资源时所面临的限制,这篇文章主要给大家介绍了关于前端uniapp微信小程序跨域问题的解决方法,需要的朋友可以参考下
    2024-08-08

最新评论