event 用 ts 类型声明

一、DOM 事件类型声明示例

1. 鼠标点击事件(`MouseEvent`)

使用 React.MouseEvent<HTMLButtonElement> 定义

javascript 复制代码
import React from "react";



const MyComponent: React.FC = () => {

  const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {

    // 这里可以访问MouseEvent的相关属性,比如获取鼠标点击的坐标

    console.log("Client X:", event.clientX);

    console.log("Client Y:", event.clientY);

  };



  return <button onClick={handleClick}>Click Me</button>;

};



export default MyComponent;

2. 键盘输入事件(`KeyboardEvent`)

使用 React.KeyboardEvent<HTMLInputElement> 定义

javascript 复制代码
import React from "react";



const MyComponent: React.FC = () => {

  const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {

    if (event.key === "Enter") {

      console.log("用户按下了回车键");

    }

  };



  return <input onKeyDown={handleKeyDown} placeholder="请输入内容" />;

};



export default MyComponent;

3. 表单提交事件(`FormEvent`)

使用 React.FormEvent<HTMLFormElement> 定义

javascript 复制代码
import React from "react";



interface FormData {

  username: string;

  password: string;

}



const MyComponent: React.FC = () => {

  const handleSubmit = (event: React.FormEvent<HTMLFormElement>) => {

    event.preventDefault();

    const formData: FormData = {

      username: (

        event.currentTarget.elements.namedItem("username") as HTMLInputElement

      ).value,

      password: (

        event.currentTarget.elements.namedItem("password") as HTMLInputElement

      ).value,

    };

    console.log("提交的表单数据:", formData);

  };



  return (

    <form onSubmit={handleSubmit}>

      <input type="text" name="username" placeholder="用户名" />

      <input type="password" name="password" placeholder="密码" />

      <button type="submit">提交</button>

    </form>

  );

};



export default MyComponent;
相关推荐
brzhang2 分钟前
干翻 Docker?WebAssembly 3.0 的野心,远不止浏览器,来一起看看吧
前端·后端·架构
lecepin1 小时前
AI Coding 资讯 2025-09-17
前端·javascript·面试
IT_陈寒1 小时前
React 18实战:7个被低估的Hooks技巧让你的开发效率提升50%
前端·人工智能·后端
树上有只程序猿2 小时前
终于有人把数据库讲明白了
前端
猩兵哥哥2 小时前
前端面向对象设计原则运用 - 策略模式
前端·javascript·vue.js
司宸2 小时前
Prompt设计实战指南:三大模板与进阶技巧
前端
RoyLin2 小时前
TypeScript设计模式:抽象工厂模式
前端·后端·typescript
华仔啊2 小时前
Vue3+CSS 实现的 3D 卡片动画,让你的网页瞬间高大上
前端·css
江城开朗的豌豆2 小时前
解密React虚拟DOM:我的高效渲染秘诀 🚀
前端·javascript·react.js