vue父組件調(diào)用子組件方法報錯問題及解決
vue父組件調(diào)用子組件方法報錯
在父組件定義了一個tab標(biāo)簽頁,每一個標(biāo)簽頁下面都調(diào)用不同的組件,
如下圖所示:

子組件中定義的方法:
setup() {
const getList = () =>{
const date = moment(new Date()).format('YYYY-MM')
loading.value = true
apiGetPageList({
salaryDate: date,
page: state.pagination.page,
limit: state.pagination.limit,
jobNo: state.formState.searchValue ? state.formState.searchValue : null
}).then((res: any)=> {
if (res.data.status == 200) {
state.dataSource = res.data.data.rows
state.pagination.total = res.data.data.total
} else {
Message.error(res.data.message ? res.data.message : "獲取數(shù)據(jù)失敗")
}
}).finally(()=>{
loading.value = false
})
}
return {
getList
}
}
父組件中使用tab標(biāo)簽頁的change方法,每次點擊不同tab頁的時候,都會調(diào)用該子組件的獲取列表數(shù)據(jù)的接口。
一開始的思路是:在父組件中調(diào)用子組件的時候使用ref屬性,通過ref拿到子組件的方法,然后在change方法中進(jìn)行調(diào)用。但在實際開發(fā)中,卻出現(xiàn)了問題,切換到tab頁時,控制臺會報錯,如下所示:

這個是因為異步執(zhí)行的原型,子組件還沒渲染完就調(diào)用方法會出現(xiàn)這樣的情況。在網(wǎng)上百度了下解決方法,只需要在子組件中定義的方法中加上this.$nextTick就可以解決。
這種方法的確可以,但我試了試另一種方法:在父組件中的change方法中加上nextTick,想驗證下是否能夠解決,結(jié)果是能夠正常調(diào)用。
代碼如下所示:
setup() {
const changeTab = (active: any) => {
switch (active) {
case "2":
console.log(33333,areaWorkDay)
nextTick(()=>{
areaWorkDay.value.editTableData = {}
areaWorkDay.value.getPageList()
areaWorkDay.value.formRef.resetFields()
})
break;
case "3":
console.log(111,monthSalaryRef)
// monthSalaryRef.value.$emit('getList')
nextTick(()=>{
monthSalaryRef.value.editTableData = {}
monthSalaryRef.value.getList()
monthSalaryRef.value.monthRef.resetFields()
})
break;
}
}
return {
changeTab
}
}
這樣也可以解決父組件調(diào)用子組件的時候,因為異步執(zhí)行,子組件方法還沒初始化完成,導(dǎo)致控制臺報錯的問題。
vue父組件調(diào)用子組件方法及遇到的問題
在子組件methods選項中定義方法method(),在父組件中引用子組件,并在子組件標(biāo)簽中定義ref=‘xxx’,使用this.$refs.xxx.method()調(diào)用子組件方法。
但chrome控制臺報錯該方法undifined,原因是因為使用ref調(diào)用子組件是調(diào)用的實例,但調(diào)用時該實例還未加載完,因此調(diào)用的方法undifined。
解決方法:在父組件中調(diào)用時,先加載完組件實例再調(diào)用方法:
this.$nextTick( () => {
?? ?this.$refs.xxx.method()
} )以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue中使用better-scroll實現(xiàn)輪播圖組件
better-scroll 是一款重點解決移動端(已支持 PC)各種滾動場景需求的插件。這篇文章主要介紹了Vue中使用better-scroll實現(xiàn)輪播圖組件的實例代碼,需要的朋友可以參考下2020-03-03
element中async-validator異步請求驗證使用
本文主要介紹了element中async-validator異步請求驗證使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
vue2.0與bootstrap3實現(xiàn)列表分頁效果
這篇文章主要為大家詳細(xì)介紹了vue2.0與bootstrap3實現(xiàn)列表分頁效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11

