Vue/React子組件實例暴露方法(TypeScript)
最近幾個月都在用TS開發(fā)各種項目,框架有涉及到Vue3,React18等;
記錄一下Vue/React組件暴露出變量/函數(shù)的方法的寫法;
Vue2
回顧一下Vue2 組件暴露出去方法,它并沒有約束,寫在methods里的方法都能被調用,data里的變量也能被接收;
現(xiàn)拉一個vue 2.6.10的模板下來
子組件的數(shù)據(jù)
父組件獲取子組件實例,調用子組件方法等;
控制臺輸出:
這個輸出的子組件實例里包含所有的變量和方法;
Vue3
組件通過vue3提供的defineExpose方法,把需要暴露出去的函數(shù)/變量放入到該方法里;
<script setup lang="ts"> import { defineExpose, ref } from 'vue'; ... // 舉個例子 const name = ref('ikun'); function setName(name: string) { name.value = name; } defineExpose({ name, setName }) </script>
父組件
同樣在子組件上聲明一個ref對象接收這個子組件實例;為了能自動識別出暴露的方法,需要指定這個ref對象的類型;
此時可以在任意方法里訪問這個子組件暴露出來的數(shù)據(jù)
<script setup lang="ts"> import { ref } from 'vue'; interface ChildInstance { name: string setName: (name: string) => void } const child = ref<ChildInstance >(); // 調用此方法即可改變子組件里的數(shù)據(jù) function test() { child.value?.setName('xxx') console.log(child.value?.name) } </script> <template> ... <Child ref="child" /> </template>
React
react函數(shù)式組件已經跟vue3差不多了,只不過是名字不一樣而已;
在react中,通過useImperativeHandle這個hook+高階組件formRef來暴露出組件的方法;
貼一下某個業(yè)務代碼片段
子組件暴露出去的方法
這其中BasicImpHandle 就是暴露的方法類型接口;
父組件
render
Vue3和React獲取的子組件實例不會像Vue2那樣暴露全部的方法和數(shù)據(jù)了,只會暴露定義好的數(shù)據(jù)出來,感覺更安全吧;
就醬.
到此這篇關于Vue/React子組件實例暴露方法(TypeScript)的文章就介紹到這了,更多相關react組件暴露內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue-resource 攔截器(interceptor)的使用詳解
本篇文章主要介紹了vue-resource 攔截器(interceptor)的使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07Vue指令v-for遍歷輸出JavaScript數(shù)組及json對象的常見方式小結
這篇文章主要介紹了Vue指令v-for遍歷輸出JavaScript數(shù)組及json對象的常見方式,結合實例形式總結分析了vue.js使用v-for指令遍歷輸出js數(shù)組與json對象的常見操作技巧,需要的朋友可以參考下2019-02-02vue?element-plus圖片預覽實現(xiàn)方法
這篇文章主要給大家介紹了關于vue?element-plus圖片預覽實現(xiàn)的相關資料,最近的項目中有圖片預覽的場景,也是踩了一些坑,在這里總結一下,需要的朋友可以參考下2023-07-07