前端开发笔记 | React Hooks子组件和父组件交互

文章通过一个实例展示了在React中使用Hooks进行开发时,如何实现子组件调用父组件的方法以及子组件改变父组件状态的功能。通过useState和useCallbackHook,子组件能够更新父组件中的按钮文案,体现了ReactHooks在组件通信中的简便性。
摘要由CSDN通过智能技术生成

前端开发框架目前比较常用的就是react、vue等,其中使用React Hooks 带来了不少的好处,今天来聊聊React Hooks开发方式下,子组件和父组件的交互。

父组件调用子组件

子组件定义

import React from "react";

type Props = {
  btnText: string;
  onClick: () => void;
};

const Sub = (props: Props) => {
  const { btnText, onClick } = props;
  return (
    <div>
      <button onClick={onClick}>{btnText}</button>
    </div>
  );
};

export default Sub;

父组件调用子组件

import React, { useCallback, useState } from "react";
import Sub from "./sub";

const Parent = () => {
  const [btnText, setBtnText] = useState("测试");

  const changeBtnText = useCallback(() => {
    setBtnText("改变按钮文案");
  }, []);
  return (
    <div>
      <Sub btnText={btnText} onClick={changeBtnText} />
    </div>
  );
};

export default Parent;

子组件改变父组件

父组件定义

import React, { useCallback, useState } from "react";
import Sub from "./sub";

const Parent = () => {
  const [btnText, setBtnText] = useState("测试");

  const changeBtnText = useCallback((value: string) => {
    setBtnText(value);
  }, []);
  return (
    <div>
      <button>{btnText}</button>
      <Sub changeBtnText={changeBtnText} />
    </div>
  );
};

export default Parent;

子组件中刷新父组件按钮文案

import React from "react";

type Props = {
  changeBtnText: (value: string) => void;
};

const Sub = (props: Props) => {
  const { changeBtnText } = props;

  return (
    <div>
      <button
        onClick={() => {
          console.log("改变父组件按钮");
          changeBtnText("改变按钮文案");
        }}
      >
        改变父组件按钮
      </button>
    </div>
  );
};

export default Sub;

实际效果:点击子组件中“改变父组件按钮”,父组件中按钮的文案从“测试”变成了“改变按钮文案“,同时在Console中输出”改变父组件按钮“,成功在子组件中刷新了父组件按钮文案。


这就是使用React Hooks开发方式下,子组件和父组件的交互,非常简单易懂,React Hooks确实是很好用呢,大大方便了前端开发。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值