vue3 ref獲取不到子組件的解決方法
需求
在父組件內(nèi)調(diào)用子組件內(nèi)的事件從而改變子組件的某些狀態(tài),父子組件使用<script setup>
語(yǔ)法糖,父組件通過(guò)給子組件定義ref訪(fǎng)問(wèn)其內(nèi)部事件。這看起來(lái)完全沒(méi)毛病,理想很豐滿(mǎn),現(xiàn)實(shí)很骨感,寫(xiě)完就是訪(fǎng)問(wèn)不到,還報(bào)錯(cuò),離離原上譜,這究竟是為啥
經(jīng)過(guò)一番調(diào)查,我才明白setup語(yǔ)法糖需要用defineExpose把要讀取的屬性和方法單獨(dú)暴露出去
,這就不得不反思一下自己當(dāng)初是怎么學(xué)習(xí)的使用setup語(yǔ)法糖,回想好像只是在查閱資料時(shí)看到有人貼了一段代碼是這樣方式就直接照貓畫(huà)虎的直接使用,根本沒(méi)有去查閱官方文檔去細(xì)致全面的學(xué)習(xí),呼倫吞棗是真的會(huì)挖很多坑等待自己探索
下面我做了一個(gè)測(cè)試,我創(chuàng)建兩個(gè)子組件,一個(gè)使用setup語(yǔ)法糖,另一個(gè)使用setup()函數(shù),都在父組件通過(guò)ref去訪(fǎng)問(wèn),打印看結(jié)果
父組件:HomeView.vue
<template> <div class="home"> <myChild ref="child" /> <myChild2 ref="child2" /> <button @click="add">點(diǎn)擊</button> </div> </template> <script setup> import myChild from './myChild.vue' import myChild2 from './myChild2.vue' import { ref } from 'vue' const child = ref(null) const child2 = ref(null) const add = () => { console.log('child=>', child.value, '========', 'child2=>', child2.value) // child.value.insert() // child2.value.insert() } </script>
子組件1:myChild.vue
<template> <div class="about"> <h1 @click="insert">myChild:{{ num }}</h1> </div> </template> <script setup> import { ref } from 'vue' const num = ref(0) const insert = () => { num.value++ } </script>
子組件2:myChild2.vue
<template> <div class="about"> <h1 @click="insert">myChild2:{{ num }}</h1> </div> </template> <script> import { ref } from 'vue' export default { setup () { const num = ref(0) const insert = () => { num.value++ } return { num, insert } } } </script>
結(jié)果
從下圖結(jié)果可以看出,可以通過(guò)ref訪(fǎng)問(wèn)myChild2組件,但是無(wú)法訪(fǎng)問(wèn)myChild組件,
原因
vue3項(xiàng)目使用<script setup>
語(yǔ)法糖相比于使用setup()
函數(shù)會(huì)更加方便簡(jiǎn)潔,但前者會(huì)將組件私有化
,也就是說(shuō)使用<script setup>的組件中的數(shù)據(jù)和事件無(wú)法被外部訪(fǎng)問(wèn)
,此時(shí)父組件就無(wú)法通過(guò)ref去訪(fǎng)問(wèn)該子組件。
除非主動(dòng)對(duì)外暴露 setup 中的數(shù)據(jù)和方法,使用 defineExpose
API,此時(shí)你可以向外暴露任何你允許外部訪(fǎng)問(wèn)的
<!-- myChild --> <script setup> import { ref, defineExpose } from 'vue' const num = ref(0) const insert = () => { num.value++ } // 向外暴露 insert 事件 defineExpose({ insert, a: 1, b: 2 }) </script>
到此這篇關(guān)于vue3 ref獲取不到子組件的解決方法的文章就介紹到這了,更多相關(guān)vue3 ref獲取不到子組件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue項(xiàng)目打包優(yōu)化方式(讓打包的js文件變小)
這篇文章主要介紹了vue項(xiàng)目打包優(yōu)化方式(讓打包的js文件變小),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04關(guān)于vue3.0使用axios報(bào)錯(cuò)問(wèn)題
這篇文章主要介紹了vue3.0使用axios報(bào)錯(cuò)問(wèn)題記錄,vue-cli3.0安裝插件的時(shí)候要注意區(qū)分vue-cli2.0的命令,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08vue如何使用element ui表格el-table-column在里面做判斷
這篇文章主要介紹了vue如何使用element ui表格el-table-column在里面做判斷問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Vue學(xué)習(xí)筆記進(jìn)階篇之單元素過(guò)度
這篇文章主要介紹了Vue學(xué)習(xí)筆記進(jìn)階篇之單元素過(guò)度,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07Vue按回車(chē)鍵進(jìn)行搜索的實(shí)現(xiàn)方式
這篇文章主要介紹了Vue按回車(chē)鍵進(jìn)行搜索的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01Vue中this.$refs獲取為undefined的原因和解決辦法(this.$refs.屬性為undefined原因
在Vue項(xiàng)目開(kāi)發(fā)中,使用this.$refs訪(fǎng)問(wèn)組件或DOM元素的引用時(shí),可能會(huì)遇到獲取為undefined的情況,這篇文章主要介紹了Vue中this.$refs獲取為undefined的原因和解決辦法,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-11-11vue修改數(shù)據(jù)的時(shí)候,表單值回顯不正確問(wèn)題及解決
這篇文章主要介紹了vue修改數(shù)據(jù)的時(shí)候,表單值回顯不正確的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11