react 事件冒泡 阻止默认事件

事件冒泡

e.stopPropagation

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

export default function Toolbar() {
  return (
    <div className="Toolbar" onClick={(e) => {
      
      alert('你点击了 toolbar !');
    }}>
      <Button onClick={() => alert('正在播放!')}>
        播放电影
      </Button>
      <Button onClick={() => alert('正在上传!')}>
        上传图片
      </Button>
    </div>
  );
}
  • 点击播放电影,会调用播放电影的事件+弹出点击了boolbar这两个,这里在子组件中添加了阻止事件冒泡,他就不会再去执行父组件的""点击了boolbar"" 这个函数

阻止默认行为

复制代码
export default function Signup() {
  return (
    <form onSubmit={e => {
      e.preventDefault();
      alert('提交表单!');
    }}>
      <input />
      <button>发送</button>
    </form>
  );
}
  • 不要混淆 e.stopPropagation() 和 e.preventDefault()。它们都很有用,但二者并不相关+
  • e.stopPropagation() 阻止触发绑定在外层标签上的事件处理函数。
  • e.preventDefault() 阻止少数事件的默认浏览器行为。
相关推荐
GIS之路5 分钟前
GDAL 实现创建几何对象
前端
liulilittle19 分钟前
CLANG 交叉编译
linux·服务器·开发语言·前端·c++
自信阿杜34 分钟前
跨标签页数据同步完全指南:如何选择最优通信方案
前端·javascript
牛马11144 分钟前
WidgetsFlutterBinding.ensureInitialized()在 Flutter Web 端启动流程的影响
java·前端·flutter
Captaincc1 小时前
2025: The year in LLMs
前端·vibecoding
指尖跳动的光1 小时前
Vue的nextTick()方法
前端·javascript·vue.js
码事漫谈1 小时前
可能,AI早都觉醒了
前端
qq_406176142 小时前
JS 事件循环(Event Loop)
开发语言·前端·javascript
Codebee2 小时前
ooder A2UI ES6版本正式发布:现代化模块架构,MIT开源许可
前端
Devin_chen2 小时前
4.前端使用Node + MongoDB + Langchain消息管理与聊天历史存储
前端·langchain