Elementui Radio单选框取消选中

问题:

最近开发一个后台项目的时候用到了单选框,而客户的要求是默认选择一个选项,然后点击可以取消选中。不想自己在手写一个Radio组件,只能在elementui的单选框上修改一下下啦。

1. .native的作用

.native的作用是在给组件添加修饰符时,将修饰符转为原生的按键修饰符。在使用组件库的时候,因为组件没有自己定义一个@click事件,所以需要加一个.native,这样就调用了原生js的事件

解决方法:

第一种(不推荐):

**思路:**使用.native触发原生js的点击事件,然后在用prevent来阻止组建的默认事件。但是这种方法会造成样式缺失。

javascript 复制代码
<!-- template-->
<el-radio-group v-model="checkRadio"  @click.native.prevent="pendingRes($event)">
    <el-radio :label="item.id" v-for="item in pendingItems" :key="item.id" >
        {{ item.label }}
    </el-radio>
</el-radio-group>

data() {
    checkRadio:0
}

//js
pendingRes(event) {
    if (event.target.tagName === "INPUT") {
         let id = event.target.value
         if (this.checkRadio != id) {
             console.log('选中')
        } else {
             console.log('取消选中')
          this.checkRadio = 0
        }
    }
},

tips:点击事件触发了一次,但是造成了选中后的样式丢失

第二种(推荐):

**思路:**只使用native来触发原生js事件,然后通过原生事件的作用域来区分是否点击选择按钮。

javascript 复制代码
<!-- template-->
<el-radio-group v-model="checkRadio"  @click.native.prevent="pendingRes($event)">
    <el-radio :label="item.id" v-for="item in pendingItems" :key="item.id" >
        {{ item.label }}
    </el-radio>
</el-radio-group>

data() {
    checkRadio:0
}

//js
pendingRes(event) {
    if (event.target.tagName === "INPUT") {
         let id = event.target.value
         if (this.checkRadio != id) {
             console.log('选中')
        } else {
             console.log('取消选中')
          this.checkRadio = 0
        }
    }
},

tips:事件触发了两次,样式未丢失。

因为原生click事件会执行两次,第一次在label标签上,第二次在input标签, 这个时候我们就可以以这个来区分

总结:

1.两种方法都可以达到取消选中的要求。

2.不在意样式的选用第一种,要求样式的选择第二种 。

相关推荐
里欧跑得慢1 天前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒1 天前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
cn_mengbei1 天前
用React Native开发OpenHarmony应用:Reanimated共享元素过渡
javascript·react native·react.js
kyriewen1 天前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真1 天前
我自己写的第一个skills--project-core-standards
前端·agent
Data_Journal1 天前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库
掌心向暖RPA自动化1 天前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
竹林8181 天前
wagmi v2 多链钱包切换:一个 Uniswap 仿盘项目让我踩了三天坑
前端·javascript
donecoding1 天前
Playwright MCP 页面捕获:Snapshot、截图、HTML 到底选哪个?
前端·ai编程·前端工程化
你也向往长安城吗1 天前
最快的 JavaScript navmesh pathfinding3d 算法。
javascript