Vue生命周期與setup深入詳解
生命周期
下圖對比了vue3(左)和vue2(右)的生命周期:vue3將destoryed該名成了unmounted,相應的beforeDestory改成了beforeUnmounted。除此之外在組合式API中新增了個鉤子函數(shù):setup。它發(fā)生在beforeCreate之前。
先簡單介紹下setup函數(shù):
- setup() 鉤子是在組件中使用組合式 API 的入口
- setup中沒有this
- setup函數(shù)只會在組件初始化的時候執(zhí)行一次
- setup函數(shù)在beforeCreate生命周期鉤子執(zhí)行之前執(zhí)行
生命周期函數(shù)
與vue2不同,vue3中使用生命周期函數(shù)需要先導入生命周期鉤子函數(shù),并且生命周期函數(shù)可以調(diào)用多次。
<script lang="ts"> import { onMounted } from 'vue' export default { setup() { onMounted(() => { console.log('mounted') }) onMounted(() => { console.log('mounted two') }) } } </script>
你也可以使用setup語法糖,看起來更簡潔一些。
<script setup lang="ts"> import { onMounted } from 'vue' onMounted(() => { console.log('mounted') }) onMounted(() => { console.log('mounted two') }) </script> <style scoped> </style>
不同API的生命周期
選項式API | 組合式API |
---|---|
beforeCreate | 不需要(直接寫到setup函數(shù)中) |
created | 不需要(直接寫到setup函數(shù)中) |
beforeMount | onBeforeMount |
mounted | onMounted |
beforeUpdate | onBeforeUpdate |
updated | onUpdated |
beforeDestroyed | onBeforeUnmount |
destroyed | onUnmounted |
setup介紹
1. 訪問Props
setup 函數(shù)的第一個參數(shù)是組件的 props。和標準的組件一致,一個 setup 函數(shù)的 props 是響應式的,并且會在傳入新的 props 時同步更新。
export default { props: { title: String }, setup(props) { // 注意這里不要解構(gòu)props,這樣會使解構(gòu)出來的變量失去響應性。如果一定要解構(gòu)需要使用響應式api轉(zhuǎn)發(fā)下。 console.log(props.title) } }
2. setup上下文
傳入 setup 函數(shù)的第二個參數(shù)是一個 Setup 上下文對象。上下文對象暴露了其他一些在 setup 中可能會用到的值:
export default { setup(props, context) { // 透傳 Attributes(非響應式的對象,等價于 $attrs) console.log(context.attrs) // 插槽(非響應式的對象,等價于 $slots) console.log(context.slots) // 觸發(fā)事件(函數(shù),等價于 $emit) console.log(context.emit) // 暴露公共屬性(函數(shù)) console.log(context.expose) } }
與props不同,上下文對象是非響應式的,可以安全地解構(gòu):
export default { setup(props, { attrs, slots, emit, expose }) { ... } }
attrs 和 slots 的屬性都不是響應式的。如果你想要基于 attrs 或 slots 的改變來執(zhí)行副作用,那么你應該在 onBeforeUpdate 生命周期鉤子中編寫相關(guān)邏輯。
expose函數(shù)用于顯式地限制該組件暴露出的屬性,當父組件通過模板引用訪問該組件的實例時,將僅能訪問 expose 函數(shù)暴露出的內(nèi)容:
export default { setup(props, { expose }) { // 讓組件實例處于 “關(guān)閉狀態(tài)” // 即不向父組件暴露任何東西 expose() const publicCount = ref(0) const privateCount = ref(0) // 有選擇地暴露局部狀態(tài) expose({ count: publicCount }) } }
3. 與渲染函數(shù)一起使用
setup 也可以返回一個渲染函數(shù),此時在渲染函數(shù)中可以直接使用在同一作用域下聲明的響應式狀態(tài):
import { h, ref } from 'vue' export default { setup() { const count = ref(0) return () => h('div', count.value) } }
返回一個渲染函數(shù)將會阻止我們返回其他東西。對于組件內(nèi)部來說,這樣沒有問題,但如果我們想通過模板引用將這個組件的方法暴露給父組件,那就有問題了。
可以通過調(diào)用 expose() 解決這個問題:
import { h, ref } from 'vue' export default { setup(props, { expose }) { const count = ref(0) const increment = () => ++count.value expose({ increment }) return () => h('div', count.value) } }
這樣父組件可以通過模板引用來訪問這個 increment 方法。
到此這篇關(guān)于Vue生命周期與setup深入詳解的文章就介紹到這了,更多相關(guān)Vue生命周期內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3?setup語法糖各種語法新特性的使用方法(vue3+vite+pinia)
這篇文章主要介紹了vue3?setup語法糖各種語法新特性的使用(vue3+vite+pinia),本文主要是記錄vue3的setup語法糖的各種新語法的使用方法,需要的朋友可以參考下2022-09-09elementUi vue el-radio 監(jiān)聽選中變化的實例代碼
這篇文章主要介紹了elementUi vue el-radio 監(jiān)聽選中變化,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-06-06vue 實現(xiàn)通過手機發(fā)送短信驗證碼注冊功能
這篇文章主要介紹了vue 實現(xiàn)通過手機發(fā)送短信驗證碼注冊功能的相關(guān)資料,需要的朋友可以參考下2018-04-04如何在vue3.0+中使用tinymce及實現(xiàn)多圖上傳文件上傳公式編輯功能
本文給大家分享tinymce編輯器如何在vue3.0+中使用tinymce及實現(xiàn)多圖上傳文件上傳公式編輯功能,tinymce安裝方法文中也給大家詳細介紹了,對vue tinymce實現(xiàn)上傳公式編輯相關(guān)知識感興趣的朋友跟隨小編一起學習下吧2021-05-05vue3中ts語法使用element plus分頁組件警告錯誤問題
這篇文章主要介紹了vue3中ts語法使用element plus分頁組件警告錯誤問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04