Vue3使用setup監(jiān)聽props實現(xiàn)方法詳解
背景描述
子組件展示父組件傳來的參數(shù),展示的信息隨著父組件上tab的切換動態(tài)更新。
一開始的想法是單獨監(jiān)聽這個傳遞的參數(shù),但看了VUE3的文檔之后,似乎對參數(shù)的監(jiān)聽必須精確到屬性。例如參數(shù)為
{ name: 'Doctor', gender: 'Timelord' }
需要在子組件的watch
中寫明監(jiān)聽的是name
還是gender
。
該參數(shù)中有很多可能會改變的屬性,一一監(jiān)聽過于麻煩。所以改變思路,使用監(jiān)聽props來獲取所有所有傳參。
實現(xiàn)方法
在父組件中,用于傳遞給子組件的參數(shù)必須為響應式(eg. reactive
),否則子組件在監(jiān)聽時不會監(jiān)測到變換,watch永遠不會生效
immediate
是立即開始監(jiān)聽,在頁面首次渲染時可能為顯示為undefined,如果watch的變化需要手動觸發(fā),不需要開啟
deep
默認開啟,可以忽略(參數(shù)為reactive,會默認開啟deep,如果是ref,則不會默認開啟deep)
// 父組件 <script> export default { setup() { let traveller = reactive({ name: 'Doctor', gender: 'Timelord' }) } } </script>
// 子組件 <script> export default { props: { traveller: { type: Object } } setup(props) { watch( props, (old, newProps) => { console.log('=======', newProps); //這里看到新值 }, // { // immediate: true, // deep: true // } ) } } </script>
以上就是Vue3使用setup監(jiān)聽props實現(xiàn)方法詳解的詳細內容,更多關于Vue3 setup監(jiān)聽props的資料請關注腳本之家其它相關文章!
相關文章
antd?select?多選限制個數(shù)的實現(xiàn)代碼
這篇文章主要介紹了antd?select?多選限制個數(shù),實現(xiàn)思路和核心代碼都很簡單,其中核心代碼在于disabled,代碼簡單易懂需要的朋友可以參考下2022-11-11VUE3+vite項目中動態(tài)引入組件與異步組件的詳細實例
在做vue3項目中時,每次使用都需要先進行引入,下面這篇文章主要給大家介紹了關于VUE3+vite項目中動態(tài)引入組件與異步組件的相關資料,需要的朋友可以參考下2022-09-09element-ui table行點擊獲取行索引(index)并利用索引更換行順序
這篇文章主要介紹了element-ui table行點擊獲取行索引(index)并利用索引更換行順序,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02