vue,小程序,uni-app的生命周期

在Web开发、小程序开发以及使用uni-app进行跨平台开发时,理解各个框架或平台的生命周期是非常重要的。这些生命周期钩子允许开发者在组件或应用的特定阶段执行代码,比如初始化、显示、隐藏、销毁等。下面分别介绍Vue、小程序和uni-app的生命周期。

Vue的生命周期

Vue的生命周期主要指的是Vue实例从创建到销毁的一系列过程。这些过程包括:

  1. beforeCreate:在实例初始化之后,数据观测(data observer) 和 event/watcher 事件配置之前被调用。
  2. created:实例已经创建完成之后被立即调用。在这一步,实例已完成以下的配置:数据观测(data observer),属性和方法的运算,watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。
  3. beforeMount:在挂载开始之前被调用:相关的 render 函数首次被调用。该钩子在服务器端渲染期间不被调用。
  4. mounted:el 被新创建的 vm.el替换,并挂载到实例上去之后调用该钩子。如果根实例挂载了一个文档内元素,当mounted被调用时vm.el 也在文档内。
  5. beforeUpdate:数据更新时调用,发生在虚拟 DOM 打补丁之前。这里适合在更新之前访问现有的 DOM,比如手动移除已添加的事件监听器。
  6. updated:由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用这个钩子。当这个钩子被调用时,组件 DOM 已经更新,所以你现在可以执行依赖于 DOM 的操作。
  7. beforeDestroy:实例销毁之前调用。在这一步,实例仍然完全可用。
  8. destroyed:Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

小程序的生命周期

小程序的生命周期主要关注页面的加载、显示、隐藏、卸载等过程,以及全局的启动、显示等。以微信小程序为例:

  • 全局生命周期
    • onLaunch:当小程序初始化完成时,会触发 onLaunch(全局只触发一次)
    • onShow:当小程序启动,或从后台进入前台显示,会触发 onShow
    • onHide:当小程序从前台进入后台,会触发 onHide
    • onError:当小程序发生脚本错误,或者 api 调用失败时,会触发 onError 并带上错误信息
  • 页面生命周期
    • onLoad:页面加载时触发。一个页面只会调用一次 onLoad,可以在 onLoad 的参数中获取打开当前页面路径中的参数。
    • onShow:页面显示/切入前台时触发。
    • onReady:页面初次渲染完成时触发。一个页面只会调用一次 onReady,代表页面已经准备妥当,可以和视图层进行交互。
    • onHide:页面隐藏/切入后台时触发。 如 navigateTo 或底部 tab 切换到其他页面,小程序切入后台等。
    • onUnload:页面卸载时触发。如 redirectTo 或 navigateBack 到其他页面时。

uni-app的生命周期

uni-app支持Vue的生命周期,同时扩展了应用级别的生命周期和页面级别的生命周期,以支持跨平台开发。

  • 应用生命周期(App.vue):
    • onLaunch:当uni-app 初始化完成时触发(全局只触发一次)
    • onShow:当 uni-app 启动,或从后台进入前台显示
    • onHide:当 uni-app 从前台进入后台
    • onError:当 uni-app 报错时触发
  • 页面生命周期(页面的.vue文件):
    • onLoad:监听页面加载,其参数为上个页面传递的数据,参数类型为Object(用于页面传参)
    • onShow:监听页面显示。每次打开页面都会调用一次。
    • onReady:监听页面初次渲染完成。注意如果渲染速度快,会在onShow之后很快调用
    • onHide:监听页面隐藏
    • onUnload:监听页面卸载

uni-app还提供了其他如onPullDownRefresh(监听用户下拉动作)、onReachBottom(页面上拉触底事件的处理函数)等页面特有的生命周期钩子。

  • 20
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 的 render 函数是 Vue.js 中一个非常重要的概念。它是用来描述组件如何渲染的函数。在 Vue 中,我们可以使用模板语法来编写组件的渲染逻辑,也可以使用 render 函数来编写。 使用 render 函数,你可以直接返回一个虚拟 DOM 对象,描述组件的结构和行为。这个函数接收一个参数,通常命名为 h(代表 createElement),它是一个用于创建 VNode(虚拟节点)的函数。 在 render 函数中,你可以通过调用 h 函数来创建 VNode,然后返回一个或多个 VNode 组成的树形结构。VNode 是对真实 DOM 的一种抽象表示,它包含了节点的标签名、属性、子节点等信息。 以下是一个简单的例子,演示了如何使用 render 函数创建一个简单的 Vue 组件: ```javascript // 定义一个组件 const MyComponent = { render(h) { return h('div', { class: 'container' }, [ h('h1', {}, 'Hello, Vue!'), h('p', {}, 'This is a Vue component.') ]) } } // 使用组件 new Vue({ el: '#app', render: h => h(MyComponent) }) ``` 这个例子中,我们定义了一个名为 MyComponent 的组件,在 render 函数中返回了一个包含 h1 和 p 标签的 div 元素。在 new Vue 的时候,我们将 render 函数指定为 MyComponent,从而将组件渲染到具有 id 为 app 的元素中。 通过使用 render 函数,你可以更灵活地控制组件的渲染逻辑,实现更高级的功能。它提供了一种编程式的方式来构建组件,而不仅仅局限于模板语法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值