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

