日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

react-native?父函數(shù)組件調(diào)用類子組件的方法(實(shí)例詳解)_React

作者:龍卷風(fēng)吹毀停車場(chǎng) ? 更新時(shí)間: 2022-11-10 編程語(yǔ)言

react-native 父函數(shù)組件調(diào)用類子組件的方法,代碼如下所示:

import React, {Component} from 'react';
import {Text, View,  TouchableOpacity} from 'react-native';

// 父
let child
onRefbbb = (ref) => {
    child = ref
}
clickccc = () => {
    child.myName()
}
const Parent =()=> {
        return(
            <View>
                <Child onRefaaa={onRefbbb} />
                <TouchableOpacity onPress={()=>clickccc()}>
                    <Text>onClick</Text>
                </TouchableOpacity>
            </View>
        )
}
export default Parent

// 子
class Child extends Component {
    componentDidMount(){
        this.props.onRefaaa(this)
    }

     myName = () =>{
        alert(11111111111111)
     }

    render() {
        return (<View></View>)
    }
}

補(bǔ)充:下面看下React 函數(shù)式組件之父組件調(diào)用子組件的方法

前言:

最近做一個(gè)React項(xiàng)目,所有組件都使用了函數(shù)式組件,遇到一個(gè)父組件調(diào)用子組件方法的問題,讓我好一陣頭疼。

我們都知道,React 中子組件調(diào)用父組件方法,使用 props 傳遞過來(lái)就可以在子組件中使用。但是父組件如何調(diào)用子組件方法呢?請(qǐng)看下面代碼:

第一步:

在父組件中,使用 useRef 創(chuàng)建一個(gè) ref

import { useRef } from 'react'
// 父組件中代碼
const FCom = () => {
    const cRef = useRef(null);
    return (
        <div>
            <ChildCom ref={cRef} />
        </div>
    )
}

第二步:

子組件中代碼:(使用了 forwardRef,useImperativeHandle)

import { forwardRef, useImperativeHandle } from 'react'
const ChildCom = forwardRef(({
  // 這里是一些props參數(shù)
}, ref) => {
    useImperativeHandle(ref, () => ({
        getData: getData,
        otherFun: otherFun
    }))
    function getData() {
        // to do something
    }
    function otherFun() {
        console.log('這是其他方法')
    }
    return (
        <div>子組件</div>
    )
})

第三步:

此時(shí),在父組件中就可以隨心所欲的調(diào)用子組件中的方法了!

import { useRef } from 'react'
// 修改父組件中代碼
const FCom = () => {
    const cRef = useRef(null);
    const handleClick = () => {
        cRef.current && cRef.current.getData()
    }
    return (
        <div>
            <ChildCom ref={cRef} />
        </div>
    )
}

原文鏈接:https://www.cnblogs.com/tlfe/p/16671868.html

欄目分類
最近更新