React组件通信

React组件通信

父子间组件通信:

父传子的流程:

  1. 父组件传递数据 子组件标签身上绑定属性

  2. 子组件接收数据

子传父的流程:

  1. 父组件传递数据子组件标签身上绑定属性

  2. 在子组件中调用父组件中的函数,并将自己的数据作为一个实参传过去

typescript 复制代码
//父传子
//1.父组件传递数据 子组件标签身上绑定属性
//2.子组件接收数据
//子传父
//1.父组件传递数据 子组件标签身上绑定属性
//2.在子组件中调用父组件中的函数,并将自己的数据作为一个实参传过去
import { useState } from 'react'
function Article ({ title, content, active, onGetHandleChange }) {
  return (
    <div>
      {/* 子组件接收数据 */}
      <h2>{title}</h2>
      <p>{content}</p>
      <p>状态:{active ? '显示中' : '已隐藏'}</p>
      {/* 子传父:在子组件中调用父组件中的函数并传递参数 */}
      <button onClick={() => onGetHandleChange(title)}>点击</button>
    </div>
  )
}

export default function App () {
  //父传子:父组件传递数据
  const articleData = {
    title:'标题1'
  }
  //声明一个状态数据开看一下视图的变化
  const [activeTitle, setActiveTitle] = useState('')
  //子传父:父组件声明一个函数
  function handleChange (title) {
    console.log(title)
    //更新状态数据
    setActiveTitle(title)
  }
  return (
    <div>
      {/* 父传子:子组件身上绑定属性 */}
      <Article
        onGetHandleChange={handleChange}
        title={articleData.title}
        content="内容1"
        active
      />
      <Article
        onGetHandleChange={handleChange}
        title="标题2"
        content="内容2"
      />
      <Article
        onGetHandleChange={handleChange}
        title="标题3"
        content="内容3"
        active
      />
    </div>
  )
}

兄弟组件通信:

typescript 复制代码
// 子传父:子组件调用父组件中的函数,并将自己的数据作为一个实参传递进去
import React, { useState } from "react"

function A({ onGetName }) {
  // Son组件中的数据
  const name = "this is A name"

  return (
    <div>
      this is A component, {name}
      {/* 将A中的数据作为一个实参传递过去 */}
      <button onClick={() => onGetName(name)}>send</button>
    </div>
  )
}

function B({ name }) {
  return (
    <div>
      this is B component, {name}
    </div>
  )
}

function App() {
  // 声明一个状态函数
  const [name, setName] = useState("")
  // 父组件中的函数
  const getAName = (name) => {
    console.log(name)
    // 通过调用这个状态方法存进状态变量里面去
    setName(name)
  }
  return (
    <div>
      this is App
      {/* 将函数绑定给子组件 */}
      <A onGetName={getAName} />
      <B name={name} />
    </div>
  )
}

export default App

跨层级组件通信:

实现步骤:

  1. 使用 createContext 方法创建一个上下文对象 Ctx

  2. 在顶层组件(App)中通过 Ctx.Provider 组件提供数据

  3. 在底层组件(B)中通过 useContext 钩子函数获取消费数据

javascript 复制代码
import React, { createContext, useContext } from 'react'
//1. createContext方法创建一个上下文对象
export const MyContext = createContext()
//2.顶层组件中 通过Context.Provider组件提供上下文值
//3.底层组件中 通过useContext钩子函数使用数据

function A () {
  return (
    <div>
      this is A component
      <B />
    </div>
  )
}

function B () {
  //4.通过useContext钩子函数使用数据
  const msg = useContext(MyContext)
  return (
    <div>
      this is B component, msg is {msg}
    </div>
  )
}

function App () {
  const msg = 'this is app msg'
  return (
    <div>
      {/*value是提供数据的,就是你要传递的数据 */}
      <MyContext.Provider value={msg}>
      this is App
      <A />
      </MyContext.Provider>
    </div>
  )
}

export default App
相关推荐
漂流瓶jz4 小时前
总结CSS组件化演进之路:命名规范/CSS Modules/CSS in JS/原子化CSS
前端·javascript·css
踩着两条虫5 小时前
「AI + 低代码」的可视化设计器
开发语言·前端·低代码·设计模式·架构
Jagger_5 小时前
项目上线忙碌结束之后,为什么总想找点事做?
前端
GalenZhang8885 小时前
OpenClaw 配置多个飞书账号实战指南
前端·chrome·飞书·openclaw
萌新小码农‍6 小时前
python装饰器
开发语言·前端·python
threelab7 小时前
Three.js 初中数学函数可视化 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
爱学习的程序媛7 小时前
浏览器工作原理全景解析
前端·浏览器·web
我是若尘8 小时前
用 Git Worktree 同时开多个需求,不用来回 stash
前端
IT_陈寒8 小时前
Vue的v-for为什么不加key也能工作?我差点翻车
前端·人工智能·后端
小碗羊肉9 小时前
【JavaWeb | 第十二篇】项目实战——登录功能
java·前端·数据库