国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

解決react-connect中使用forwardRef遇到的問題

瀏覽:171日期:2022-06-10 10:30:28
目錄
  • react-connect使用forwardRef遇到的問題
    • 項目場景
    • 原因
    • 問題描述
    • 解決方案
  • React.forwardRef的使用說明
    • 應用場景
    • 但問題來了
  • 總結

    react-connect使用forwardRef遇到的問題

    項目場景

    之前獨立的兩個tab, tab1和tab2, 由于需求變更, 要把這兩個tab都放到一個tab4下, 變化大概是從圖1變為圖2

    原因

    子組件用了使用了connect, 相當于把forwardRef隔離了,導致父組件拿不到想要的方法, 所以需要把forwardRef 透傳給使用了connect 的子組件

    問題描述

    tip: 該文章以下內容中說的子組件指tab1和tab2, 父組件指tab4

    tab1和tab2組件都有"更新數據"按鈕,將他們合并為tab4里面之后,"更新數據"按鈕已經變成了父組件(tab4)的內容, 但是由于按鈕的onClick事件中的邏輯太復雜, 所以點擊事件沒有挪出來重新寫到父組件里。

    也就是:按鈕在父組件中, 按鈕的點擊事件在子組件里寫。

    子組件和父組件都是用函數組件 + Hook 寫的, 并且子組件中都用了connect, 此時父組件想調用子組件的點擊事件方法, 該怎么拿到子組件里的方法呢?

    解決方案

    tip: 我的項目使用的是umi2

    利用Hoc(高階組件)透傳ref

    import React, { forwardRef, useImperativeHandle, useState, useEffect } from "react";import { connect } from "dva"const Children = (props) => {  const { refInstance } = props  const [text, setText] = useState("子組件:Children")  const functionA = () => {    console.log("c2方法")    setText("ref改變了")  }  useImperativeHandle(refInstance, () => ({    functionA,    text,  }))return (    <div>      {text}    </div>)}const newA =  connect((state) => {  return {    list: state.list,  }})(Children)// 使用Hoc 透傳 refexport default forwardRef((props, ref) => <newA  {...props} refInstance={ref} />);

    React.forwardRef的使用說明

    forwardRef實際上就是當父組件需要得到子組件元素時,可以利用forwardRef來實現。

    該方法接受一個有額外ref參數的react組件函數,不調用該方法,普通的組件函數是不會獲得該參數的。

    應用場景

    ref 的作用是獲取實例,可能是 DOM 實例,也可能是 ClassComponent 的實例。

    但問題來了

    如果目標組件是一個 FunctionComponent 的話,是沒有實例的(PureComponent),此時用 ref 去傳遞會報錯

    React.forwardRef 會創建一個React組件,這個組件能夠將其接受的 ref 屬性轉發到其組件樹下的另一個組件中。這種技術并不常見,但在以下兩種場景中特別有用:

    • 轉發 refs 到 DOM 組件
    • 在高階組件中轉發 refs

    實例:

    點擊搜索按鈕時,讓文本輸入框處于聚焦狀態

    1、普通用法:

    import React, { Component } from "react"export default class App extends Component {? mytext=null? render() {? ? return (? ? ? <div>? ? ? ? <button type="button" onClick={()=>{? ? ? ? ? console.log(this.mytext);? ? ? ? ? this.mytext.current.focus()? ? ? ? ? this.mytext.current.value="2222"? ? ? ? }}>獲取焦點</button>? ? ? ? <Child callback={(el)=>{? ? ? ? ? console.log(el);、? ? ? ? ? //el是臨時變量,用全局的去接這個值? ? ? ? ? this.mytext=el? ? ? ? ? //console.log(el.current);? ? ? ? }}/>? ? ? </div>? ? )? }}class Child extends Component {? mytext = React.createRef();? //組件渲染完了執行? componentDidMount() {? ? this.props.callback(this.mytext);? }? render() {? ? return (? ? ? <div style={{background:"yellow"}}>? ? ? ? <input defaultValue="1111" ref={this.mytext}></input>? ? ? </div>? ? );? }}

    2、使用forwardRef

    import React, { Component,forwardRef } from "react"export default class App_forwardRef extends Component {? mytext=React.createRef()? render() {? ? return (? ? ? <div>? ? ? <button type="button" onClick={()=>{? ? ? ? console.log(this.mytext);? ? ? ? this.mytext.current.value="2222"? ? ? }}>獲取焦點</button>? ? ? <Child ref={this.mytext}/>? ? ? </div>? ? )? }}//這里Child是函數式組件const Child=forwardRef((props,ref)=>{? ? return (? ? ? <div>? ? ? ? <input defaultValue="11111" ref={ref}></input>? ? ? </div>? ? );})

    總結

    以上為個人經驗,希望能給大家一個參考,也希望大家多多支持。

    標簽: JavaScript
    主站蜘蛛池模板: 欧美视频久久 | 亚洲精品国自产拍在线观看 | 亚洲欧美另类在线视频 | 日本中文字幕不卡免费视频 | 三级视频在线播放 | 久久狠狠躁免费观看2020 | 手机福利在线 | 日本高清免费视频www | 综合 欧美 国产 视频二区 | 久久视屏这里只有精品6国产 | 成年视频国产免费观看 | 亚洲国产日产韩国欧美综合 | 男子操女子 | 成人做爰在线视频 | 成人午夜影院在线观看 | 国产黄色小视频在线观看 | 亚洲国产精品一区二区首页 | 久久国产视频网 | 欧美成人综合在线 | 女人张开腿男人猛桶视频 | 国产成人女人在线视频观看 | 亚洲天堂视频在线观看免费 | 热er99久久6国产精品免费 | 亚洲一区二区在线免费观看 | 日韩精品特黄毛片免费看 | 三级中文字幕永久在线视频 | 国产亚洲欧美日韩在线观看一区二区 | 国产在线啪 | 全部精品孕妇色视频在线 | 免费看欧美日韩一区二区三区 | 欧美不卡视频 | 中文字幕日本一区波多野不卡 | 最新精品国产 | 国产成人看片免费视频观看 | 欧美 日韩 国产在线 | 国产va精品网站精品网站精品 | 国产在线观看一区二区三区 | 亚洲欧美在线视频 | 亚洲在线视频播放 | 成人永久福利在线观看不卡 | 久久青草国产手机看片福利盒子 |