码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • React 中事件的类型定义


    基本的事件类型

    React 搞了一套自己的事件类型,所以你没办法使用 TypeScript 内置提供的 MouseEvent 等等。在需要定义事件类型的时候,需要从 React 中导入:

    import React, { Component, MouseEvent } from 'react';
    
    export class Button extends Component {
      handleClick(event: MouseEvent) {
        event.preventDefault();
        alert(event.currentTarget.tagName); // alerts BUTTON
      }
      
      render() {
        return (
        <button onClick={this.handleClick}>
          {this.props.children}
        </button>
        );
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    React 提供的事件类型有: AnimationEvent, ChangeEvent, ClipboardEvent, CompositionEvent, DragEvent, FocusEvent, FormEvent, KeyboardEvent, MouseEvent, PointerEvent, TouchEvent, TransitionEvent, WheelEvent。还有一个 SyntheticEvent,用于其他所有的事件。

    限制性的事件类型

    如果需要限制事件类型,可以利用事件类型的泛型:

    import React, { Component, MouseEvent } from 'react';
    
    export class Button extends Component {
      /*
       * 这里我们将 handleClick 限制只能是在 HTMLButton 元素上
       */
      handleClick(event: MouseEvent<HTMLButtonElement>) {
        event.preventDefault();
        alert(event.currentTarget.tagName); // alerts BUTTON
      }
    
      /* 
       * 支持联合类型
       */
      handleAnotherClick(event: MouseEvent<HTMLButtonElement | HTMLAnchorElement>) {
        event.preventDefault();
        alert('Yeah!');
      }
    
      render() {
        return <button onClick={this.handleClick}>
          {this.props.children}
        </button>
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    这里的限定的类型是 TypeScript 提供的 DOM 元素类型。

    我是 Pandy,一个喜欢英语的程序猿 👨‍💻

    关注公众号 Yopth,回复「加群」,加入「英文技术翻译互助群」,我们加入一起充电英语 🔌

    Reference

    [1] TypeScript and React: Events

  • 相关阅读:
    这是一个隐藏的(绝世武功)Java 学习路线图,祝你Offer拿到手软
    SQL练习:表妹不在,没人帮我查表,只好自己来了
    vue之下拉菜单
    觉哥java网站踩坑+bug记录(困扰一分钟以上的问题全记录)
    Web跨域问题
    es elasticsearch 九 索引index 定制分词器 type结构后期弃用原因 定制动态映射 动态映射模板 零停机重建索引
    6163. 给定条件下构造矩阵——每日一难(phase2_day1)
    C++ 多态
    一文搞懂pytorch hook机制
    有趣简单的M2处理器性能实验:Swift与C代码执行速度的比较
  • 原文地址:https://blog.csdn.net/YopenLang/article/details/125910670
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号