vue3基于script?setup語(yǔ)法$refs的使用
一、vue2語(yǔ)法
vue2語(yǔ)法在組件上設(shè)置ref屬性后,在代碼里可以通過(guò) this.$refs.ref值 訪問(wèn)到對(duì)應(yīng)的子組件。
一個(gè)設(shè)置ref值的組件:
<base-input ref="usernameInput"></base-input>
在js代碼中可以通過(guò)如下代碼訪問(wèn)到這個(gè)組件:
this.$refs.usernameInput
可以調(diào)用里面的方法:
// 假設(shè) base-input 組件內(nèi)有方法foo this.$refs.usernameInput.foo();
詳細(xì)使用可以參考底部列出的參考文章。
二、vue3使用
網(wǎng)上找了一些文章比較零散,而且試了下都不能用,但是通過(guò)這些文章了解到了一些關(guān)鍵信息,最后整理出如下幾步:
1. 組件設(shè)置ref值
這個(gè)和vue2的類似,父組件調(diào)用子組件的時(shí)候設(shè)置ref值。
<ChildVue ref="childRef" />
2. 組件實(shí)例獲取
設(shè)置完成后,vue3可以通過(guò)ref方法獲取。
const childRef = ref();
這邊變量的名字需要和上面ref
的一致。如何直接打印childRef
,這個(gè)時(shí)候會(huì)是:
undefined
因?yàn)轫?yè)面組件還沒(méi)有掛載完成,所以需要在掛載完成之后才能正常使用。
onMounted(() => { console.log(childRef.value); // Proxy {…} });
3. 子組件內(nèi)設(shè)置對(duì)外公開的變量
上面第2步獲取到子組件實(shí)例后,無(wú)法使用子組件內(nèi)的方法,因?yàn)槭褂?code> script setup 的組件默認(rèn)是關(guān)閉的,如果需要公開,需要使用 defineExpose
編譯器宏。
// 子組件代碼 const foo = () => { console.log("foo"); } defineExpose({ foo });
父組件內(nèi)調(diào)用:
// 調(diào)用子組件方法 childRef.value.foo(); // foo
這樣就可以調(diào)用到子組件的方法了。
查看childRef.value,也可以看到其中公開的foo方法:
vue3父組件調(diào)用子組件方法
完整參考代碼:
父組件:
<template> <ChildVue ref="childRef" /> </template> <script setup lang="ts"> import { ref } from '@vue/reactivity'; import { onMounted } from '@vue/runtime-core'; import ChildVue from './Child.vue'; const childRef = ref(); console.log(childRef.value); // undefined onMounted(() => { console.log(childRef.value); // Proxy {…} // 調(diào)用子組件方法 childRef.value.foo(); // foo }); </script> <style> </style>
子組件:
<template>child demo</template> <script setup lang="ts"> const foo = () => { console.log("foo"); } defineExpose({ foo }); </script> <style> </style>
到此這篇關(guān)于vue3基于script setup語(yǔ)法$refs的使用的文章就介紹到這了,更多相關(guān)vue3 $refs的使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ElementUI動(dòng)態(tài)渲染el-table的實(shí)現(xiàn)過(guò)程
在前端開發(fā)中,表格是不可或缺的一部分,無(wú)論是數(shù)據(jù)展示、數(shù)據(jù)錄入,還是數(shù)據(jù)分析,表格都扮演著重要的角色,而在Vue.js生態(tài)系統(tǒng)中,ElementUI提供了一個(gè)強(qiáng)大且靈活的表格組件——el-table,本文將帶你深入了解如何使用ElementUI動(dòng)態(tài)渲染el-table,并詳細(xì)探討其原理及實(shí)現(xiàn)過(guò)程2024-08-08vue使用axios訪問(wèn)本地json文件404問(wèn)題及解決
這篇文章主要介紹了vue使用axios訪問(wèn)本地json文件404問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07Vue+better-scroll 實(shí)現(xiàn)通訊錄字母索引的示例代碼
通訊錄字母索引是常用的一種功能,本文主要介紹了Vue+better-scroll 實(shí)現(xiàn)通訊錄字母索引,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06vue?+?ele?實(shí)現(xiàn)下拉選擇框和下拉多選選擇框處理方案
這篇文章主要介紹了vue?+?ele?實(shí)現(xiàn)下拉選擇框和下拉多選選擇框處理方案,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08Vue3 組件間通信之mitt實(shí)現(xiàn)任意組件間通信的步驟
mitt 主要有4個(gè)API:emit(觸發(fā)某個(gè)事件)、on(綁定事件)、off(解綁某個(gè)事件)、all(獲取所有綁定的事件),這篇文章主要介紹了Vue3 組件間通信之mitt實(shí)現(xiàn)任意組件間通信,需要的朋友可以參考下2024-05-05