vue3?使用defineExpose的實(shí)例詳解
可以通過(guò) defineExpose 編譯器宏來(lái)顯式指定在 <script setup> 組件中要暴露出去的屬性:
<script setup>
import { ref } from 'vue'
const a = 1
const b = ref(2)
defineExpose({
a,
b
})
</script>當(dāng)父組件通過(guò)模板引用的方式獲取到當(dāng)前組件的實(shí)例,獲取到的實(shí)例會(huì)像這樣 { a: number, b: number } (ref 會(huì)和在普通實(shí)例中一樣被自動(dòng)解包)
例子
父組件
<template>
<h2>defineExpose 使用 父組件</h2>
<child ref="getChildData"></child>
</template>
<script setup lang="ts">
import Child from "@/components/exposeChildren.vue"
import { ref,onMounted,toRaw} from 'vue'
// 文檔說(shuō)setup寫(xiě)在script上組件是關(guān)閉的
// 也就是說(shuō)父組件使用getChildData.xxx訪問(wèn)不到子組件的數(shù)據(jù)
// 此時(shí)我們需要用defineExpose把需要傳遞的數(shù)據(jù)暴露出去,這樣外部才能訪問(wèn)到
// 同理也可以接收外部傳來(lái)的值
const getChildData = ref(null)
const obj = {
name: 'alan',
desc: '大笨蛋',
age: 18
}
const cc= getChildData.value?.['num']
console.log(cc) //undefined,此時(shí)還未找到子組件暴露的數(shù)據(jù)
onMounted(()=>{
//獲取子組件的data數(shù)據(jù),什么時(shí)候獲取根據(jù)自己業(yè)務(wù)來(lái)
const bb:any= getChildData.value?.['updata']
console.log(bb()) // 123,這時(shí)候得到的是子組件的初始值,因?yàn)檫€未給子組件傳遞數(shù)據(jù)
const a:any= getChildData.value?.['getData']
a(obj) ////給子組件傳遞數(shù)據(jù)
const b:any= getChildData.value?.['updata']
const c= getChildData.value?.['num']
console.log(toRaw(b())) // {name: 'alan', desc: '大笨蛋', age: 18} ,這里得到的是個(gè)proxy,所以需要toRaw()方法轉(zhuǎn)成對(duì)象
console.log(c) // 666
})
</script>
<style scoped>
</style>子組件
<template>
<h2>defineExpose 使用 子組件</h2>
<div>{{ data }}</div>
</template>
<script setup lang="ts">
import { ref, defineExpose } from 'vue'
const data = ref(123)
const num = ref(666)
defineExpose({
updata(){
return data.value //暴露出去父組件可以拿到data的數(shù)據(jù).此時(shí)值為123
},
getData(res:any){
data.value = res //父組件傳遞來(lái)的值賦值給data
// 此時(shí)的data變成了 Proxy
// {
// name: 'alan',
// desc: '大笨蛋',
// age: 18
// }
},
num
})
</script>
<style scoped>
</style>到此這篇關(guān)于vue3 使用defineExpose的文章就介紹到這了,更多相關(guān)vue3 使用defineExpose內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue在項(xiàng)目中如何引入本地Json數(shù)據(jù)
這篇文章主要介紹了Vue在項(xiàng)目中如何引入本地Json數(shù)據(jù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
Vue2.0基于vue-cli+webpack同級(jí)組件之間的通信教程(推薦)
下面小編就為大家?guī)?lái)一篇Vue2.0基于vue-cli+webpack同級(jí)組件之間的通信教程(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09
vue watch如何深度監(jiān)聽(tīng)數(shù)組每一項(xiàng)的變化
這篇文章主要介紹了vue watch如何深度監(jiān)聽(tīng)數(shù)組每一項(xiàng)的變化問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
vue項(xiàng)目打包部署到nginx后css樣式失效的問(wèn)題及解決方法
我將自己的前端Vue項(xiàng)目,經(jīng)過(guò)build生成的dist文件夾copy到nginx的html文件夾中,然后寫(xiě)了配置文件,運(yùn)行訪問(wèn)后發(fā)現(xiàn)頁(yè)面css樣式?jīng)]有加載到,下面給大家介紹vue項(xiàng)目打包部署到nginx后css樣式失效的問(wèn)題及解決方法,感興趣的朋友一起看看吧2024-12-12
vue-devtools 打開(kāi)源碼位置實(shí)現(xiàn)過(guò)程
這篇文章主要為大家介紹了vue-devtools 打開(kāi)源碼位置實(shí)現(xiàn)過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
Vue實(shí)現(xiàn)contenteditable元素雙向綁定的方法詳解
contenteditable是所有HTML元素都有的枚舉屬性,表示元素是否可以被用戶編輯。本文將詳細(xì)介紹如何實(shí)現(xiàn)contenteditable元素的雙向綁定,需要的可以參考一下2022-05-05
vue項(xiàng)目打包發(fā)布到Nginx后無(wú)法訪問(wèn)后端接口的解決辦法
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目打包發(fā)布到Nginx后無(wú)法訪問(wèn)后端接口的解決辦法,記錄一下項(xiàng)目需要注意的地方,方便以后快速使用,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04
Vue?echarts@4.x中國(guó)地圖及AMap相關(guān)API使用詳解
這篇文章主要為大家介紹了Vue使用echarts@4.x中國(guó)地圖及AMap相關(guān)API使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12

