欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解React?hooks組件通信方法

 更新時(shí)間:2022年07月26日 14:08:33   作者:曲鳥(niǎo)  
這篇文章主要介紹了React?hooks組件通信,在開(kāi)發(fā)中組件通信是React中的一個(gè)重要的知識(shí)點(diǎn),本文通過(guò)實(shí)例代碼給大家講解react hooks中常用的父子、跨組件通信的方法,需要的朋友可以參考下

一、前言

組件通信是React中的一個(gè)重要的知識(shí)點(diǎn),下面列舉一下 react hooks中常用的父子、跨組件通信的方法

二、父子組件通信

1)父組件傳值給子組件

子組件代碼:

//子組件
const Child = ({ param1, param2 }) => {
  return <>父組件傳遞的參數(shù):{param1},{param2}</>
}

param1、param2 為子組件接收父組件的傳參,父組件代碼如下:

父組件代碼

//父組件
const Parent = () => {
  return <Child //子組件
    params1="1"
    params2="2"
  />
}

運(yùn)行效果

2)子組件傳值給父組件

子傳父嚴(yán)格來(lái)講還是父?jìng)髯?,父組件傳遞給子組件ref,子組件將想要暴露給父組件的值放在上面,然后父組件就可以使用其值:

首先需要導(dǎo)入對(duì)應(yīng)的模塊包useImperativeHandle、useRef,forwardRef

import React, { useRef, useImperativeHandle, useEffect, forwardRef } from 'react';

父組件代碼

//父組件

const Parent = () => {//父組件
  const ref = useRef(); //ref
  useEffect(() => {
    console.log(ref)
  }, [])
  return (
    <Child //子組件
      ref={ref} //將ref傳遞給子組件
    />)
}

子組件代碼

//子組件
const Child = forwardRef(({ },ref) => {
  useImperativeHandle(ref, () => ({
    data: '我是子組件'
  }));
  return <>我是子組件</>
})

運(yùn)行后控制臺(tái)輸出

{
    "current": {
        "data": "我是子組件"
    }
}

3)跨組件傳值(父?jìng)鲗O子組件)

跨組件傳值我們頁(yè)可以使用最開(kāi)始介紹的父?jìng)髯拥姆椒ǎ粚訉拥那短讉鬟f,例如:

const Parent = () => {
  return <Child1 //子組件
    param1="1"
    param2="2"
  />
}
//子組件
const Child1 = ({ param1, param2 }) => {
  return <Child2 param1={param1} param2={param2} />
}
//子子組件
const Child2 = ({ param1, param2 }) => {
  return <>父組件傳遞的參數(shù):{param1},{param2}</>
}

但如果有更多層嵌套時(shí),一層層的傳遞會(huì)顯得很冗余和麻煩,所以我們可以使用context來(lái)解決這個(gè)問(wèn)題。

在項(xiàng)目目錄創(chuàng)建一個(gè)context.js文件用于創(chuàng)建我們的context,代碼如下:

import { createContext } from 'react'
const myContext = createContext(null)
export default myContext

然后在我們組件文件中引入我們定義的myContext,并引入react對(duì)應(yīng)包:

import React, { useContext } from 'react';
import myContext from './context'

父組件代碼

const Parent = () => {
  //使用Provider傳遞值
  return <myContext.Provider value={{ param1: "1", param2: "2" }}>
    <Child1 />
  </myContext.Provider>
}

子組件和子子組件代碼

//子組件無(wú)需改動(dòng)
const Child1 = () => {
  return <Child2 />
}
//子子組件
const Child2 = () => {
  //通過(guò)useContext獲取父組件的值
  const { param1, param2 } = useContext(myContext)  
  return <>父組件傳遞的參數(shù):{param1},{param2}</>
}

運(yùn)行效果

到此這篇關(guān)于React hooks組件通信的文章就介紹到這了,更多相關(guān)React hooks組件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React函數(shù)組件useContext useReducer自定義hooks

    React函數(shù)組件useContext useReducer自定義hooks

    這篇文章主要為大家介紹了React函數(shù)組件useContext useReducer自定義hooks示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • react之umi配置國(guó)際化語(yǔ)言locale的踩坑記錄

    react之umi配置國(guó)際化語(yǔ)言locale的踩坑記錄

    這篇文章主要介紹了react之umi配置國(guó)際化語(yǔ)言locale的踩坑記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • React元素與組件的區(qū)別示例詳解

    React元素與組件的區(qū)別示例詳解

    這篇文章主要為大家介紹了React元素與組件的區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • React?Hook?Form?優(yōu)雅處理表單使用指南

    React?Hook?Form?優(yōu)雅處理表單使用指南

    這篇文章主要為大家介紹了React?Hook?Form?優(yōu)雅處理表單使用指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • 一文教你如何避免React中常見(jiàn)的8個(gè)錯(cuò)誤

    一文教你如何避免React中常見(jiàn)的8個(gè)錯(cuò)誤

    這篇文章主要來(lái)和大家一起分享在?React?開(kāi)發(fā)中常見(jiàn)的一些錯(cuò)誤,以及如何避免這些錯(cuò)誤,理解這些問(wèn)題背后的細(xì)節(jié),防止犯下類似的錯(cuò)誤,需要的可以參考下
    2023-12-12
  • 關(guān)于react的代理配置(可配置多個(gè)代理)

    關(guān)于react的代理配置(可配置多個(gè)代理)

    這篇文章主要介紹了關(guān)于react的代理配置(可配置多個(gè)代理),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • react-native 配置@符號(hào)絕對(duì)路徑配置和絕對(duì)路徑?jīng)]有提示的問(wèn)題

    react-native 配置@符號(hào)絕對(duì)路徑配置和絕對(duì)路徑?jīng)]有提示的問(wèn)題

    本文主要介紹了react-native 配置@符號(hào)絕對(duì)路徑配置和絕對(duì)路徑?jīng)]有提示的問(wèn)題,文中通過(guò)圖文示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • 如何深入理解React的ref 屬性

    如何深入理解React的ref 屬性

    關(guān)于 Refs ,React 官網(wǎng)講解的對(duì)于新手來(lái)說(shuō)不太友好,還是自己一字一句解讀后并以代碼驗(yàn)證的方式后真正理解的.
    2021-05-05
  • React?Hooks鉤子中API的使用示例分析

    React?Hooks鉤子中API的使用示例分析

    在react類組件(class)寫法中,有setState和生命周期對(duì)狀態(tài)進(jìn)行管理,但是在函數(shù)組件中不存在這些,故引入hooks(版本:>=16.8),使開(kāi)發(fā)者在非class的情況下使用更多react特性
    2022-08-08
  • 用react實(shí)現(xiàn)一個(gè)簡(jiǎn)單的scrollView組件

    用react實(shí)現(xiàn)一個(gè)簡(jiǎn)單的scrollView組件

    這篇文章主要給大家介紹一下如何用 react 實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 scrollView組件,文中有詳細(xì)的代碼示例,具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-07-07

最新評(píng)論