
如题,问了 gemini ,发现答案胡扯的,gemini 说写 onclick 不会触发 vue 响应式( ref 元素修改),但是我实测在 div 上写:onclick 确实能触发响应式修改,所以我有点纳闷,这两种写法到底有什么区别
1 BruceXu 5 天前 我的 AI 解释得很清楚,可惜没法贴给你. 简单来说,前者是原生 html 的事件,后者是 vue 的事件.和响应式是两码事,都能触发. 一般是推荐用后者,走 vue 指令系统,可以多一些功能. |
2 hengshenyu 5 天前 via Android :onClick 吧? vue 支持将事件已 props 的形式传递(声明也是),OnXxx= @xxx |
3 jspatrick 5 天前 在 jsx 或 tsx 里只有 onClick 可以用,@click 是 onClick 的简写,vue 的 template 里一般用简写,响应式只跟定义的响应式变量有关,跟函数如何绑定无关,任意函数都可以触发响应式 |
6 kakakakaka8889 5 天前 没啥区别啊,@click 只是一个语法糖就是简化的 onClick 写法而已 |
8 FakerLeung 5 天前 |
10 zhengfan2016 OP @hengshenyu 这个是在 vue 的文档的哪里啊,我好像没在文档看到这个,我能看到的就是 @click 是 v-on:click 的语法糖 https://cn.vuejs.org/guide/essentials/event-handling.html#listening-to-events |
11 94 5 天前 好难猜啊,为什么这些可以用 `v-bind` 绑定的事件都叫 [事件处理器属性]( https://developer.mozilla.org/zh-CN/docs/Web/HTML/Reference/Attributes#事件处理器属性) 呢。- [#其他事件监听器机制 | 事件介绍 - 学习 Web 开发 | MDN]( https://developer.mozilla.org/zh-CN/docs/Learn_web_development/Core/Scripting/Events#其他事件监听器机制) |
12 shakukansp 5 天前 |
13 DICK23 5 天前 vue 上应该是一致的,solidjs 中这两个写法一个是原生事件,一个是合成事件 |
14 xiaoxi123 5 天前 还是 微优易 黑魔法多啊 |
15 rich1e 5 天前 其实楼上有几位的回答,基本都对上了,总结一下就是: @click 是 Vue 封装的指令,是特有的语法糖。 - 在 .vue 文件的 <template> 里面直接使用; - @click 也可以写作 “v-on:click”; - @click 内部还封装了修饰符,e.g. '@click.stop' / '@click.once' 等等; onclick 属于 HTML 规范,跟 Vue 没关系。即便没有 Vue ,onclick 也可以工作。 多说一句,onclick 不是 onClick 。 如果想在 Vue 里面使用 onClick ,一般是指使用 jsx 编写代码,文件后缀通常为 jsx/tsx 。 当然,.vue 文件也可以写 jsx ,需要声明 `<script lang="jsx">` 或者 `<script lang="tsx">`。 PS:JSX (Javascript XML) 是 Javascript 的一种语法扩展,它允许你在 JS 代码中写出类似HTML/XML 的结构化标记。 |
16 Wanex 5 天前 没区别,@click 就是 onclick 的语法糖 |
17 tog 5 天前 |
18 Ketteiron 5 天前 我有个不相关的问题,这位老哥会被疯狂 @吗? member/click |
19 superedlimited 5 天前 via Android @Ketteiron 看上面都没啥,看到这里绷不住了 |
21 hengshenyu 5 天前 via Android @zhengfan2016 没看到相关文档,这应该不是推荐用法,但是 UI 库里常见。 https://cn.vuejs.org/guide/components/attrs.html 这里隐式提了一下 @click 这样的一个 v-on 事件监听器将在此对象下被暴露为一个函数 $attrs.onClick ,我想 props emits 也是类似。 |
22 AsuraTG 5 天前 ### 最佳实践建议 在 Vue 开发中, 永远不要使用 onclick ,原因如下: 1. 代码风格一致性 :保持所有事件绑定都走 Vue 的系统。 2. 安全性 :onclick 中的字符串代码容易引起 CSP (内容安全策略) 问题,也更容易导致 XSS 风险(如果你动态接字符串的话)。 3. 可维护性 : @click 能够清晰地指向组件内部逻辑,利于代码阅读和重构。 唯一可能用到 onclick 的场景 : 如果你正在集成某些非常古老的第三方库,或者需要在 Vue 挂载之前的极短时间内(例如 index.html 的 loading 状态)响应点击,才可能会用到原生 onclick 。但在 Vue 组件内部,请坚持使用 @click 。 |
24 zhengfan2016 OP |