React+Typescript 父子组件事件传值

好 之前我们将 state 状态管理简单过了一下

那么 本文 我们来研究一下事假处理

点击事件上文中我们已经用过了 这里 我们就不去讲了 主要来说说 父子之间的事件

我们直接来编写一个小dom

我们父组件 编写代码如下

typescript 复制代码
import Hello from "./components/hello";

function App() {
  const obtain = () => {
    console.log("调用了 父组件的obtain");
  };

  return (
    <div className="App">
      <Hello title="高阶组件" age={20} onObtain={obtain} />
    </div>
  );
}

export default App;

这里 我们定义了一个obtain函数

然后 给子组件绑定了一个 onObtain 事件 触发的函数时 指向本组件的obtain函数

然后 我们子组件编写代码如下

typescript 复制代码
import * as React from "react";

interface IProps {
    title: string,
    age: number,
    onObtain: any
}

interface IState {
    count:number
}

export default class hello extends React.Component<IProps,IState> {

    public readonly state: Readonly<IState> = {
        count: 520
    }
    
    public constructor(props:IProps){
        super(props);
        this.clickHide = this.clickHide.bind(this);
        this.requestParent = this.requestParent.bind(this);
    }

    public clickHide(){
        this.setState({
            count: 200
        })
    }

    public requestParent() {
        this.props.onObtain();
    }


    public render() {
        return (
            <div>
                <div>{ this.state.count }</div>
                <button onClick = { this.clickHide }>修改</button>
                <button onClick = { this.requestParent }>调用父组件函数</button>
            </div>
        )
    }
}

这里 我们写了个requestParent 点击按钮时触发

这里需要注意 我们函数直接在IProps中声明一下就好了 和 父组件传递的参数 props 一样

然后 我们为了方便类型直接给个any 任意类型

然后 当用户点击触发requestParent按钮时 我们调用父组件给的onObtain

我们运行项目然后点击按钮

可以看到 这个位置就没有任何问题 成功触发了

然后 我们进一步

写一个传递参数的

子组件的requestParent函数改成

typescript 复制代码
public requestParent() {
    this.props.onObtain("小猫猫");
}

这样 我们就往onObtain中传了一个字符串 值为 小猫猫

然后 我们父组件的 obtain 改成这样

typescript 复制代码
const obtain = (name:string) => {
   console.log(name);
};

这里 我们给obtain设置要接收一个参数 字符串类型的 键定义为name

然后 输出在控制台

我们再次运行项目 然后点击按钮

结果如下

也是没有任何问题

相关推荐
人工智能训练13 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪14 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
2601_9495936514 小时前
基础入门 React Native 鸿蒙跨平台开发:模拟智能音响
react native·react.js·harmonyos
xiaoqi92215 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin12332215 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头882117 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas13617 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠17 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
珑墨18 小时前
【Turbo】使用介绍
前端
军军君0118 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three