首页
学习
活动
专区
圈层
工具
发布

JSX onClick 和 HTML onclick 的区别

在 JSX 中可以通过 onClick 这样的方式给一个元素添加一个事件处理函数,当然,在 HTML 中也可以用 onclick (小写 c),但在 HTML 中直接书写 onclick 一直就是为人垢病的写法...1、onclick 添加的事件处理函数是在全局环境下执行的,这污染了全局环境,很容易产生意料不到的后果; 2、给很多 DOM 元素添加 onclick 事件,可能会影响网页的性能,毕竟,网页需要的事件处理函数越多...: 既然长期以来一直不倡导在 HTML 中使用 onclick,为什么在 React 的 JSX 中我们却要使用 onClick 这样的方式来添加事件处理函数呢?...JSX onClick 和 HTML onclick 的区别 上面 HTML onclick 的这些问题,在 JSX 中都不存在,JSX 的 onClick 事件处理方式和 HTML 的 onclick...因为 React 控制了组件的生命周期,在 unmount 的时候自然能够清除相关的所有事件处理函数,内存泄露也不再是一个问题。

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    PHPStorm 代码在 CSDN 文章中显示的相关 js 的“onclick” 代码失效情况!

    编辑器中复制了源码; > 然后直接粘贴在 csdn 的 MarkDown 编辑器中(当然是代码块中!)...; > 文章保存发表后,发现直接复制博客代码内容粘贴在自己的 PHPStorm 中时; > 排查问题发现 “onclick” 这个单词中 “o” 会失效; > 解决方法也不难,就是重新打出这个单词呗...【注意】 在此提示一下,其实文章前期,并没有出现这种问题, 因为有段时间我也是自己复制所写过的源码,但是大概在三个月前出的的这种情况 也是超级一脸懵逼… 附录【2020-07-13】 ①...为了这个问题,今天与客服沟通了下,(客服态度很好的哦)只是个人认为还是不够理想吧… ?...推测 本人推测可能是这些单引号双引号对 js代码产生的影响 因为单纯 只有 “onclick” 这个词是没问题的哦 希望不是我操作出现的BUG,不然可就丢人咯,哈哈哈 … ?

    5K20

    Android 中屏幕点击事件的实现Android onTouchEvent, onClick及onLongClick的调用机制

    事件中返回了true,那么兴许的事件将直接发给onTouchEvent,而不是继续发给onInterceptTouchEvent。...在Android中,onClick、onLongClick的触发是和ACTION_DOWN及ACTION_UP相关的,在时序上,假设我们在一个View中同一时候覆写了onClick、onLongClick...能够看出是按ACTION_DOWN -> ACTION_UP -> onClick的次序发生的。...要弄清楚这个问题仅仅要理解Android对事件处理的所谓消费(consume)概念就可以,一个用户的操作会被传递到不同的View控件和同一个控件的不同监听方法处理,不论什么一个接收并处理了该次事件的方法假设在处理完后返回了...onLongClick的发生是由单独的线程完毕的,而且在ACTION_UP之前,而onClick的发生是在ACTION_UP后,因此同一次用户touch操作就有可能既发生onLongClick又发生onClick

    5.2K30

    JavaScript中onclick事件传递数组参数时接收的是,需要转为字符串传递

    问题描述 在JavaScript中定义button的onclick点击事件,传递参数的时候,某个参数是数组,在方法体里面接收到的值是[object,object]。...直到看到下面这篇博文的时候解决了问题: js中onclick事件中传入object对象参数,将object对象转成字符串_js click传递object-CSDN博客 var data = {"report_file_name...let str= 'tabTest'; let arr= [];//数组,这里用空数组代指,比如从后台返回的List let html = 'onclick="modifyFunc(\'...是字符串数组,而不是[object,object] ... ... } 问题分析 将数组参数转换为JSON字符串是一个很好的做法,这样可以确保数组中的数据以正确的格式传递给函数。...使用replace(/"/g, '"')是一个很好的解决方案,它可以将双引号(")替换为转义的双引号("),这样可以确保字符串在传递时不会被错误地解析。

    1.5K10

    你要的react+ts最佳实践指南_2023-02-27

    任何可调用的函数 onClick: () => void; // ✅ better ,明确无参数无返回值的函数 onChange: (id: number) => void; // ✅...better ,明确参数无返回值的函数 onClick(event: React.MouseEvent): void; // ✅ better }; 可选属性...Prop 类型 如果你有配置 Eslint 等一些代码检查时,一般函数组件需要你定义返回的类型,或传入一些 React 相关的类型属性。...={title}>{children}; 争议 React.FC(or FunctionComponent)是显式返回的类型,而"普通函数"版本则是隐式的(有时还需要额外的声明)。...const initialState = { count: 0 }; // ❌ bad,可能传入未定义的 type 类型,或码错单词,而且还需要针对不同的 type 来兼容 payload // type

    4K31

    你要的react+ts最佳实践指南

    相关React实战视频讲解:进入学习函数类型函数类型不建议直接给 Function 类型,有明确的参数类型、个数与返回值类型最佳。...任何可调用的函数 onClick: () => void; // ✅ better ,明确无参数无返回值的函数 onChange: (id: number) => void; // ✅ better...,明确参数无返回值的函数 onClick(event: React.MouseEvent): void; // ✅ better};可选属性React props...Prop 类型如果你有配置 Eslint 等一些代码检查时,一般函数组件需要你定义返回的类型,或传入一些 React 相关的类型属性。...const initialState = { count: 0 };// ❌ bad,可能传入未定义的 type 类型,或码错单词,而且还需要针对不同的 type 来兼容 payload// type

    3.6K10
    领券