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() 阻止少数事件的默认浏览器行为。
相关推荐
Mapmost2 分钟前
半透明模型渲染全白?Mapmost Studio一招搞定
前端
SpiderPex7 分钟前
JavaWeb登录模块完整实现解析:从前端点击到后端验证的全流程
前端
Qhappy16 分钟前
某里连线九宫格图片wasm解密&识别
javascript
可乐爱宅着17 分钟前
在VSCode的next.js项目中更好的使用eslint/prettier工具
前端·next.js
_大学牲24 分钟前
🫡我在掘金写文章:一气之下开源 视频转无水印GIF 插件
前端·javascript
地方地方24 分钟前
深入理解 instanceof 操作符:从原理到手动实现
前端·javascript
哀木39 分钟前
useRef 为什么不能作为 useEffect 的依赖项
前端
渣哥44 分钟前
事务崩了别怪数据库!三大核心要素没掌握才是根本原因
javascript·后端·面试
渣哥1 小时前
你以为自动开启?Spring 事务支持其实还需要这几步!
javascript·后端·面试
Kisang.1 小时前
【HarmonyOS】窗口管理实战指南
前端·华为·typescript·harmonyos·鸿蒙