亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue/React子組件實例暴露方法(TypeScript)

 更新時間:2022年11月21日 10:59:58   作者:ZhuAiQuan  
最近幾個月都在用TS開發(fā)各種項目,框架有涉及到Vue3,React18等,記錄一下Vue/React組件暴露出變量/函數(shù)的方法的寫法,對vue?react組件暴露方法相關知識感興趣的朋友跟隨小編一起看看吧

最近幾個月都在用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 使用中踩過的坑

    VUE 使用中踩過的坑

    本篇是我對vue使用過程中以及對一些社區(qū)朋友提問我的問題中做的一些總結,感興趣的朋友跟隨腳本之家小編一起學習吧
    2018-02-02
  • vue實現(xiàn)動態(tài)列表點擊各行換色的方法

    vue實現(xiàn)動態(tài)列表點擊各行換色的方法

    今天小編就為大家分享一篇vue實現(xiàn)動態(tài)列表點擊各行換色的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue 查看dist文件里的結構(多種方式)

    vue 查看dist文件里的結構(多種方式)

    本文通過三種方式給大家介紹了vue 查看dist文件里的結構,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • 如何在Vue.JS中使用圖標組件

    如何在Vue.JS中使用圖標組件

    這篇文章主要介紹了如何在Vue.JS中使用圖標組件,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-08-08
  • vue-resource 攔截器(interceptor)的使用詳解

    vue-resource 攔截器(interceptor)的使用詳解

    本篇文章主要介紹了vue-resource 攔截器(interceptor)的使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • vue中實現(xiàn)路由跳轉的三種方式超詳細教程

    vue中實現(xiàn)路由跳轉的三種方式超詳細教程

    這篇文章主要介紹了vue中實現(xiàn)路由跳轉的三種方式超詳細教程,其中聲明式router-link實現(xiàn)跳轉最簡單的方法,可用組件router-link來替代a標簽,每種方式給大家講解的非常詳細需要的朋友可以參考下
    2022-11-11
  • Vue實現(xiàn)穿梭框效果

    Vue實現(xiàn)穿梭框效果

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)穿梭框效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Vue指令v-for遍歷輸出JavaScript數(shù)組及json對象的常見方式小結

    Vue指令v-for遍歷輸出JavaScript數(shù)組及json對象的常見方式小結

    這篇文章主要介紹了Vue指令v-for遍歷輸出JavaScript數(shù)組及json對象的常見方式,結合實例形式總結分析了vue.js使用v-for指令遍歷輸出js數(shù)組與json對象的常見操作技巧,需要的朋友可以參考下
    2019-02-02
  • vue?element-plus圖片預覽實現(xiàn)方法

    vue?element-plus圖片預覽實現(xiàn)方法

    這篇文章主要給大家介紹了關于vue?element-plus圖片預覽實現(xiàn)的相關資料,最近的項目中有圖片預覽的場景,也是踩了一些坑,在這里總結一下,需要的朋友可以參考下
    2023-07-07
  • Vertx基于EventBus發(fā)送接受自定義對象

    Vertx基于EventBus發(fā)送接受自定義對象

    這篇文章主要介紹了Vertx基于EventBus發(fā)送接受自定義對象,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11

最新評論