React基础 第九章(事件处理)

React中的事件处理是交互式应用的核心。本文将详细介绍如何编写事件处理函数、如何从父组件传递事件处理逻辑、事件如何传播及其阻止方法,并提供实用技巧和示例代码。

编写事件处理函数

在React中,事件处理函数建议以handle开头,后跟事件名称,如handleClick

技巧

  • 在组件内部声明事件处理函数。

示例

jsx 复制代码
function Button() {
  function handleClick() {
    alert('你点击了我!');
  }
  return <button onClick={handleClick}>点我</button>;
}

注意事项

  • 传递给事件处理函数的应该是函数本身,而不是函数调用。
  • 使用箭头函数时,确保不要立即执行函数。

正确代码

jsx 复制代码
<button onClick={handleClick}>点我</button>

错误代码

jsx 复制代码
<button onClick={handleClick()}>点我</button> // 错误:函数被立即调用

事件处理函数接收参数

在某些情况下,我们需要在事件处理函数中接收额外的参数。

技巧

  • 使用箭头函数包装事件处理函数,并传递参数。
  • 利用高阶函数返回一个事件处理函数,该函数已经绑定了所需的参数。

示例

jsx 复制代码
function ListItem({ item, onDelete }) {
  return (
    <li>
      {item.name}
      <button onClick={() => onDelete(item.id)}>删除</button>
    </li>
  );
}

注意事项

  • 避免在渲染方法中创建新的函数,这可能会导致性能问题。
  • 如果参数是事件对象本身,确保它是函数的第一个参数。

正确代码

jsx 复制代码
<button onClick={(e) => onDelete(e, item.id)}>删除</button>

错误代码

jsx 复制代码
<button onClick={onDelete(item.id)}>删除</button> // 错误:事件对象未传递

从父组件传递事件处理逻辑

父组件可以定义事件处理函数,并作为props传递给子组件。

技巧

  • 在父组件中定义事件处理函数,并通过props传递给子组件。
  • 使用props中的事件处理函数来访问父组件的状态或方法。

示例

jsx 复制代码
function PlayButton({ onPlay }) {
  return <button onClick={onPlay}>播放电影</button>;
}

function App() {
  function handlePlay() {
    alert('正在播放电影!');
  }
  return <PlayButton onPlay={handlePlay} />;
}

注意事项

  • 确保子组件正确地使用传递过来的事件处理函数。
  • 避免在子组件中直接执行父组件传递的函数。

正确代码

jsx 复制代码
<PlayButton onPlay={handlePlay} />

错误代码

jsx 复制代码
<PlayButton onPlay={handlePlay()} /> // 错误:函数被立即调用

事件传播与阻止

React中的事件会沿DOM树向上冒泡。有时我们需要阻止这种冒泡行为,这在处理复杂的嵌套结构时非常有用。

技巧

  • 使用event.stopPropagation()来阻止事件冒泡。
  • 在事件处理函数中接收事件对象,并使用它来阻止冒泡。

示例

jsx 复制代码
function Button({ onClick, children }) {
  return (
    <button onClick={(e) => {
      e.stopPropagation();
      onClick();
    }}>
      {children}
    </button>
  );
}

注意事项

  • 只在需要阻止冒泡的时候使用event.stopPropagation()
  • 不要混淆event.stopPropagation()event.preventDefault()

正确代码

jsx 复制代码
<button onClick={(e) => {
  e.stopPropagation();
  onClick();
}}>点我</button>

错误代码

jsx 复制代码
<button onClick={(e) => {
  e.preventDefault(); // 错误:应该使用stopPropagation来阻止冒泡
  onClick();
}}>点我</button>

阻止默认事件

有时我们需要阻止浏览器的默认行为,例如阻止表单提交的默认页面刷新。

技巧

  • 使用event.preventDefault()来阻止默认行为。
  • 在事件处理函数中接收事件对象,并使用它来阻止默认行为。

示例

jsx 复制代码
function Form() {
  function handleSubmit(e) {
    e.preventDefault();
    alert('表单已提交!');
  }
  return <form onSubmit={handleSubmit}>...</form>;
}

注意事项

  • 仅在确实需要阻止默认行为时使用event.preventDefault()
  • 不要忘记在异步事件处理函数中调用event.preventDefault()

正确代码

jsx 复制代码
<form onSubmit={handleSubmit}>...</form>

错误代码

jsx 复制代码
<form onSubmit={alert('提交!')}>...</form> // 错误:默认行为未被阻止

使用传统函数式还是箭头函数

事件处理函数既可以使用传统的函数声明,也可以使用箭头函数。两者在大多数情况下都可以互换使用,然而箭头函数是一种非常流行和方便的方式来定义事件处理函数,因为它们不仅语法简洁,而且避免了this绑定的问题。使用箭头函数定义事件处理器是一种常见的做法,尤其是当你需要在事件处理器中访问组件的状态或props时。

示例中使用传统的函数声明是为了说明React中不同的函数定义方式,并没有特别的理由偏好一种方式。在实际的函数式组件开发中,我们通常会看到如下的箭头函数用法:

jsx 复制代码
const Form = () => {
  const handleSubmit = (e) => {
    e.preventDefault();
    alert('表单已提交!');
  };

  return <form onSubmit={handleSubmit}>...</form>;
};

在这个例子中,handleSubmit是一个箭头函数,它直接定义在组件内部,这样可以确保它能够访问到组件的其他状态和props(如果有的话)。由于箭头函数不会创建自己的this上下文,它们在函数式组件中非常适用。

通过掌握这些事件处理技巧和注意事项,你可以更好地管理React应用中的用户交互。正确地使用事件处理函数不仅能提高应用的响应性,还能避免不必要的问题。记住,合理地组织事件处理逻辑,是构建高效、可维护React应用的关键。

相关推荐
cy玩具18 分钟前
点击评论详情,跳到评论页面,携带对象参数写法:
前端
qq_390161771 小时前
防抖函数--应用场景及示例
前端·javascript
John.liu_Test2 小时前
js下载excel示例demo
前端·javascript·excel
Yaml42 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事2 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶2 小时前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json
getaxiosluo2 小时前
react jsx基本语法,脚手架,父子传参,refs等详解
前端·vue.js·react.js·前端框架·hook·jsx
理想不理想v2 小时前
vue种ref跟reactive的区别?
前端·javascript·vue.js·webpack·前端框架·node.js·ecmascript
知孤云出岫2 小时前
web 渗透学习指南——初学者防入狱篇
前端·网络安全·渗透·web
贩卖纯净水.2 小时前
Chrome调试工具(查看CSS属性)
前端·chrome