vue生命周函数

在这里插入图片描述1.new Vue():new 了一个vue的实例,此时会进入组件的创建状态;
2.init:初始化组件的事件和生命周期函数
3.created():此时能访问到data和methods,可用,经常在created函数阶段发起ajax请求
4.编译模板页面
5.mounted():此时页面已经真正的渲染好了。在使用第三方插件的时候,需要在mounted阶段初始化
6.updated():会根据数据的变化触发

在 UniApp 中,Vue2 和 Vue3 的生命周期钩子函数存在一定的差异。Vue3 的生命周期钩子函数与 Vue2 相比有所变化,主要是为了更好地支持组合式 API 和更清晰的生命周期管理。 ### Vue2 生命周期钩子函数 在 Vue2 中,生命周期钩子函数主要包括以下几个阶段: - `beforeCreate`:实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。 - `created`:实例已经创建完成,属性已经绑定,但 DOM 还未生成。 - `beforeMount`:挂载开始之前被调用。 - `mounted`:DOM 已经挂载完毕。 - `beforeUpdate`:数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。 - `updated`:数据更新后,DOM 已经更新。 - `beforeDestroy`:实例销毁之前调用。 - `destroyed`:实例销毁后调用。 ### Vue3 生命周期钩子函数 Vue3 的生命周期钩子函数主要变化在于引入了组合式 API,并且钩子函数名称有所更改,以更好地反映其作用: - `onBeforeMount`:与 Vue2 的 `beforeMount` 类似。 - `onMounted`:与 Vue2 的 `mounted` 类似。 - `onBeforeUpdate`:与 Vue2 的 `beforeUpdate` 类似。 - `onUpdated`:与 Vue2 的 `updated` 类似。 - `onBeforeUnmount`:与 Vue2 的 `beforeDestroy` 类似。 - `onUnmounted`:与 Vue2 的 `destroyed` 类似。 ### UniApp 中的页面生命周期 在 UniApp 中,页面的生命周期还包括一些特定的方法,如 `onLoad` 和 `onShow`,这些方法需要从 `@dcloudio/uni-app` 模块中引入并使用[^2]。 ### Vue2 到 Vue3 的迁移 在从 Vue2 迁移到 Vue3 的过程中,需要注意一些语法上的变化,例如 `slot="xxx"` 的用法不再支持,应使用 `v-slot:xxx` 代替[^3]。 ### 示例代码 #### Vue2 示例 ```vue <template> <div> <uni-nav-bar> <view slot="left" class="city"> <!-- ... --> </view> </uni-nav-bar> </div> </template> <script> export default { beforeCreate() { console.log('Vue2 beforeCreate'); }, created() { console.log('Vue2 created'); }, beforeMount() { console.log('Vue2 beforeMount'); }, mounted() { console.log('Vue2 mounted'); } }; </script> ``` #### Vue3 示例 ```vue <template> <div> <uni-nav-bar> <template v-slot:left> <view class="city"> <!-- ... --> </view> </template> </uni-nav-bar> </div> </template> <script setup> import { onBeforeMount, onMounted } from 'vue'; onBeforeMount(() => { console.log('Vue3 onBeforeMount'); }); onMounted(() => { console.log('Vue3 onMounted'); }); </script> ``` ### 总结 Vue3 的生命周期钩子函数与 Vue2 相比更加简洁明了,同时也更好地支持了组合式 API。在 UniApp 中,页面的生命周期还包括一些特定的方法,如 `onLoad` 和 `onShow`,这些方法需要从 `@dcloudio/uni-app` 模块中引入并使用。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值