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

React父組件如何調(diào)用子組件的方法推薦

 更新時間:2023年11月20日 15:51:08   作者:visionke  
在React中,我們經(jīng)常在子組件中調(diào)用父組件的方法,一般用props回調(diào)即可,這篇文章主要介紹了React父組件如何調(diào)用子組件的方法推薦,需要的朋友可以參考下

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

本教程操作環(huán)境:Windows7系統(tǒng)、react18版、Dell G3電腦。

在React中,我們經(jīng)常在子組件中調(diào)用父組件的方法,一般用props回調(diào)即可。但是有時候也需要在父組件中調(diào)用子組件的方法,通過這種方法實現(xiàn)高內(nèi)聚。有多種方法,請按需服用。

類組件中

1、React.createRef()

  • 優(yōu)點:通俗易懂,用ref指向。
  • 缺點:使用了HOC的子組件不可用,無法指向真是子組件

比如一些常用的寫法,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)點:ref寫法簡潔
  • 缺點:使用了HOC的子組件不可用,無法指向真是子組件(同上)

使用方法和上述的一樣,就是定義ref的方式不同。

...
<Sub ref={ref => this.sub = ref}></Sub>
...

3、使用props自定義onRef屬性

  • 優(yōu)點:假如子組件是嵌套了HOC,也可以指向真實子組件。
  • 缺點:需要自定義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)點: 1、寫法簡單易懂 2、假如子組件嵌套了HOC,也可以指向真實子組件
  • 缺點: 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

這個方法其實更適合自定義HOC。但問題是,withRouter、connect、Form.create等方法并不能拋出ref,假如Child本身就需要嵌套這些方法,那基本就不能混著用了。forwardRef本身也是用來拋出子元素,如input等原生元素的ref的,并不適合做組件ref拋出,因為組件的使用場景太復雜了。

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ù)有兩種情況

  • 子組件無HOC嵌套:推薦使用ref直接調(diào)用
  • 有HOC嵌套:推薦使用自定義props的方式

到此這篇關(guān)于React父組件怎么調(diào)用子組件的方法的文章就介紹到這了,更多相關(guān)React父組件調(diào)用子組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用React?SSR寫Demo一學就會

    使用React?SSR寫Demo一學就會

    這篇文章主要為大家介紹了使用React?SSR寫Demo實現(xiàn)教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • react 兄弟組件如何調(diào)用對方的方法示例

    react 兄弟組件如何調(diào)用對方的方法示例

    這篇文章主要介紹了react 兄弟組件如何調(diào)用對方的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • react?component?function組件使用詳解

    react?component?function組件使用詳解

    這篇文章主要為大家介紹了react?component?function組件的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 一文學會使用Remix寫API接口

    一文學會使用Remix寫API接口

    這篇文章主要為大家介紹了一文學會Remix寫API接口實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • React?18?如何更新?state?中的對象

    React?18?如何更新?state?中的對象

    state 中可以保存任意類型的JavaScript值,包括對象,但是,不應該直接修改存放在 React state 中的對象,這篇文章主要介紹了React?18更新state中的對象,需要的朋友可以參考下
    2023-08-08
  • React反向代理及樣式獨立詳解

    React反向代理及樣式獨立詳解

    這篇文章主要介紹了React反向代理及樣式獨立詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08
  • react腳手架配置代理的實現(xiàn)

    react腳手架配置代理的實現(xiàn)

    本文主要介紹了react腳手架配置代理的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • react-router browserHistory刷新頁面404問題解決方法

    react-router browserHistory刷新頁面404問題解決方法

    本篇文章主要介紹了react-router browserHistory刷新頁面404問題解決方法,非常具有實用價值,需要的朋友可以參考下
    2017-12-12
  • React彈窗使用方式NiceModal重新思考

    React彈窗使用方式NiceModal重新思考

    這篇文章主要為大家介紹了React彈窗使用方式NiceModal重新思考分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • react 原生實現(xiàn)頭像滾動播放的示例

    react 原生實現(xiàn)頭像滾動播放的示例

    這篇文章主要介紹了react 原生實現(xiàn)頭像滾動播放的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04

最新評論