React Hooks中父組件中調(diào)用子組件方法

/* child子組件 */

// https://reactjs.org/docs/hooks-reference.html#useimperativehandle

import?{useState, useImperativeHandle} from?'react';

...

// props子組件中需要接受ref

const ChildComp = ({cRef}) => {

????const [val, setVal] = useState();

????// 此處注意useImperativeHandle方法的的第一個參數(shù)是目標(biāo)元素的ref引用

????useImperativeHandle(cRef, () => ({

????????// changeVal 就是暴露給父組件的方法

????????changeVal: (newVal) => {

??????????setVal(newVal);

????????}

????}));

????...

????return?(

????????<div>{val}</div>

????)

}

/* FComp 父組件 */

import?{useRef} from 'react;

...

const FComp = () => {

????const childRef = useRef();

????const updateChildState = () => {

????????// changeVal就是子組件暴露給父組件的方法

????????childRef.current.changeVal(99);

????}

????...

????return?(

????????<>

????????????{/* 此處注意需要將childRef通過props屬性從父組件中傳給自己 cRef={childRef} */}

????????????<ChildComp? cRef={childRef} />

????????????<button onClick={updateChildState}>觸發(fā)子組件方法</button>

????????</>

????)

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容