React父組件如何調(diào)用子組件的方法推薦
調(diào)用方法:1、類組件中的調(diào)用可以利用React.createRef()、ref的函數(shù)式聲明或props自定義onRef屬性來(lái)實(shí)現(xiàn);2、函數(shù)組件、Hook組件中的調(diào)用可以利用useImperativeHandle或forwardRef拋出子組件ref來(lái)實(shí)現(xiàn)。

本教程操作環(huán)境:Windows7系統(tǒng)、react18版、Dell G3電腦。
在React中,我們經(jīng)常在子組件中調(diào)用父組件的方法,一般用props回調(diào)即可。但是有時(shí)候也需要在父組件中調(diào)用子組件的方法,通過(guò)這種方法實(shí)現(xiàn)高內(nèi)聚。有多種方法,請(qǐng)按需服用。
類組件中
1、React.createRef()
- 優(yōu)點(diǎn):通俗易懂,用ref指向。
- 缺點(diǎn):使用了HOC的子組件不可用,無(wú)法指向真是子組件
比如一些常用的寫法,mobx的@observer包裹的子組件就不適用此方法。
import React, { Component } from 'react';
class Sub extends Component {
callback() {
console.log('執(zhí)行回調(diào)');
}
render() {
return <div>子組件</div>;
}
}
class Super extends Component {
constructor(props) {
super(props);
this.sub = React.createRef();
}
handleOnClick() {
this.sub.callback();
}
render() {
return (
<div>
<Sub ref={this.sub}></Sub>
</div>
);
}
}2、ref的函數(shù)式聲明
- 優(yōu)點(diǎn):ref寫法簡(jiǎn)潔
- 缺點(diǎn):使用了HOC的子組件不可用,無(wú)法指向真是子組件(同上)
使用方法和上述的一樣,就是定義ref的方式不同。
...
<Sub ref={ref => this.sub = ref}></Sub>
...3、使用props自定義onRef屬性
- 優(yōu)點(diǎn):假如子組件是嵌套了HOC,也可以指向真實(shí)子組件。
- 缺點(diǎn):需要自定義props屬性
import React, { Component } from 'react';
import { observer } from 'mobx-react'
@observer
class Sub extends Component {
componentDidMount(){
// 將子組件指向父組件的變量
this.props.onRef && this.props.onRef(this);
}
callback(){
console.log("執(zhí)行我")
}
render(){
return (<div>子組件</div>);
}
}
class Super extends Component {
handleOnClick(){
// 可以調(diào)用子組件方法
this.Sub.callback();
}
render(){
return (
<div>
<div onClick={this.handleOnClick}>click</div>
<Sub onRef={ node => this.Sub = node }></Sub>
</div>)
}
}函數(shù)組件、Hook組件
1、useImperativeHandle
- 優(yōu)點(diǎn): 1、寫法簡(jiǎn)單易懂 2、假如子組件嵌套了HOC,也可以指向真實(shí)子組件
- 缺點(diǎn): 1、需要自定義props屬性 2、需要自定義暴露的方法
import React, { useImperativeHandle } from 'react';
import { observer } from 'mobx-react'
const Parent = () => {
let ChildRef = React.createRef();
function handleOnClick() {
ChildRef.current.func();
}
return (
<div>
<button onClick={handleOnClick}>click</button>
<Child onRef={ChildRef} />
</div>
);
};
const Child = observer(props => {
//用useImperativeHandle暴露一些外部ref能訪問的屬性
useImperativeHandle(props.onRef, () => {
// 需要將暴露的接口返回出去
return {
func: func,
};
});
function func() {
console.log('執(zhí)行我');
}
return <div>子組件</div>;
});
export default Parent;2、forwardRef
使用forwardRef拋出子組件的ref
這個(gè)方法其實(shí)更適合自定義HOC。但問題是,withRouter、connect、Form.create等方法并不能拋出ref,假如Child本身就需要嵌套這些方法,那基本就不能混著用了。forwardRef本身也是用來(lái)拋出子元素,如input等原生元素的ref的,并不適合做組件ref拋出,因?yàn)榻M件的使用場(chǎng)景太復(fù)雜了。
import React, { useRef, useImperativeHandle } from 'react';
import ReactDOM from 'react-dom';
import { observer } from 'mobx-react'
const FancyInput = React.forwardRef((props, ref) => {
const inputRef = useRef();
useImperativeHandle(ref, () => ({
focus: () => {
inputRef.current.focus();
}
}));
return <input ref={inputRef} type="text" />
});
const Sub = observer(FancyInput)
const App = props => {
const fancyInputRef = useRef();
return (
<div>
<FancyInput ref={fancyInputRef} />
<button
onClick={() => fancyInputRef.current.focus()}
>父組件調(diào)用子組件的 focus</button>
</div>
)
}
export default App;總結(jié)
父組件調(diào)子組件函數(shù)有兩種情況
- 子組件無(wú)HOC嵌套:推薦使用ref直接調(diào)用
- 有HOC嵌套:推薦使用自定義props的方式
到此這篇關(guān)于React父組件怎么調(diào)用子組件的方法的文章就介紹到這了,更多相關(guān)React父組件調(diào)用子組件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用React?SSR寫Demo一學(xué)就會(huì)
這篇文章主要為大家介紹了使用React?SSR寫Demo實(shí)現(xiàn)教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
react 兄弟組件如何調(diào)用對(duì)方的方法示例
這篇文章主要介紹了react 兄弟組件如何調(diào)用對(duì)方的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10
react?component?function組件使用詳解
這篇文章主要為大家介紹了react?component?function組件的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
react-router browserHistory刷新頁(yè)面404問題解決方法
本篇文章主要介紹了react-router browserHistory刷新頁(yè)面404問題解決方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-12-12
react 原生實(shí)現(xiàn)頭像滾動(dòng)播放的示例
這篇文章主要介紹了react 原生實(shí)現(xiàn)頭像滾動(dòng)播放的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

