Vue2单选框点击后可取消勾选的一种解决办法

Vue2单选框点击后可取消勾选的一种解决办法

因为原生html5的单选框一旦选中后无法指定取消勾选,于是在实践中尝试出了以下方法

通过鼠标事件来取消勾选

待修改的原生html代码

<template>
	<input type="radio" name="gender"><input type="radio" name="gender"><template/>

思路是,在点击事件发生前判断radio的 checked 的值,如果为 false,将被点击的标签的 checked 改为 false
但是如果将方法绑定在 click 事件上,实际不会获得点击前的 checked 值,只会获得点击事件完成后的值

<template>
	<input type="radio" name="gender" @click="radioClick"><input type="radio" name="gender"><template/>
methods:{
   
	redioClick(e){
   
		console.log('checked-0', e.target.checked)
		// 控制台输出:checked-0 true
	}
}

于是改用 mousedown 事件,但是radio标签本身具有click事件,因此无论在何种状态下点击单选框,radio都会自动勾选上,所以为了阻碍click,用vue的事件修饰符 prevent 来阻止click发生

<template>
	<input type="radio" name="gender" @mousedown="radioClick" @click.prevent><input type="radio" name="gender"><template/>
methods:{
   
	redioClick(e){
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值