阻止 form 表单 input 回车触发 button 按钮 click 事件

5 篇文章 0 订阅
本文探讨了在Vue中,由于form表单默认行为导致的回车键触发Action事件的问题,并提供了两种解决方案:为button添加type='button'属性或为input添加@keydown.enter.prevent监听器。详细解释了问题的原因并给出了相应的代码示例,帮助开发者优化表单交互体验。
摘要由CSDN通过智能技术生成

问题

<form @submit.prevent>
	<button @click="Action">点击事件但并不是提交表单</button>
	<input type="file" @input="uploadLogo" />
	<input type="text" name="name" autocomplete="off"/>
</form>

如上代码,在 input 输入框中按下回车键会自动触发 Action 事件,这就会影响业务流程,也算是个bug,但这是为什么呢?

原因

因为在 form 表单中 button 有三种类型(type=)submit、button、reset ,默认为 submit
当不加 type=“button” 的时候在input框回车,button就会被当做 submit 调用。

解决

方法1:给 button 加 type 类型

<button type="button" @click="Action">点击事件但并不是提交表单</button>

方法2:给 input 加阻止回车鼠标事件

<input type="text" name="name" autocomplete="off" @keydown.enter.prevent/>

选择哪种方法就看你的 form 表单中修改哪个更方便一点,
如果 button 少,那当然选择方法1,如果 input 少,选择方法2,根据自己的代码情况选择

相关链接

vue 阻止事件冒泡,捕获方法
阻止 form input 输入框按回车自动提交表单

我的个人博客有空来坐坐

https://www.wangyanan.online

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值