React父組件怎么調(diào)用子組件的方法-環(huán)球短訊

          來(lái)源:php中文網(wǎng) | 2022-12-27 18:46:18 |


          (資料圖片僅供參考)

          本教程操作環(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)按需服用。

          類(lèi)組件中

          1、React.createRef()

          優(yōu)點(diǎn):通俗易懂,用ref指向。

          缺點(diǎn):使用了HOC的子組件不可用,無(wú)法指向真是子組件

          比如一些常用的寫(xiě)法,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寫(xiě)法簡(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"@observerclass 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、寫(xiě)法簡(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能訪問(wèn)的屬性  useImperativeHandle(props.onRef, () => {    // 需要將暴露的接口返回出去    return {      func: func,    };  });  function func() {    console.log("執(zhí)行我");  }  return <div>子組件</div>;});export default Parent;

          2、forwardRef

          使用forwardRef拋出子組件的ref

          這個(gè)方法其實(shí)更適合自定義HOC。但問(wèn)題是,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的方式

          以上就是React父組件怎么調(diào)用子組件的方法的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!

          關(guān)鍵詞: React.js

          精品久久香蕉国产线看观看亚洲| 亚洲Av无码专区国产乱码DVD| 亚洲AV本道一区二区三区四区| 亚洲欧洲久久av| 亚洲免费福利视频| 亚洲国产精品一区二区久久| 亚洲线精品一区二区三区 | 亚洲第一视频在线观看免费| 亚洲av午夜国产精品无码中文字| 国产成人亚洲综合一区| 亚洲另类自拍丝袜第1页| 亚洲色成人网一二三区| 亚洲综合一区二区精品导航| 久久亚洲精品成人777大小说| 亚洲国产精品福利片在线观看| 亚洲日韩中文字幕在线播放| 亚洲色无码专区在线观看| 亚洲愉拍99热成人精品热久久 | 亚洲成无码人在线观看| 亚洲精品在线播放| 亚洲精品资源在线| 在线观看亚洲一区二区| 亚洲黄色免费网站| 亚洲欧洲校园自拍都市| 亚洲中文字幕久在线| 亚洲精品国产免费| 亚洲成人免费网址| 亚洲国产激情在线一区| 最新亚洲春色Av无码专区| 中文字幕乱码亚洲无线三区| 亚洲欧美日韩综合俺去了| 亚洲成av人在线观看网站| 激情婷婷成人亚洲综合| 亚洲国产综合人成综合网站| 久久亚洲中文字幕精品一区四| 亚洲色精品aⅴ一区区三区| 亚洲精品国产成人片| 亚洲高清在线视频| 亚洲精品亚洲人成在线麻豆| 亚洲av日韩av综合| 亚洲熟女乱色一区二区三区|