element中el-switch用法汇总(拓展:el-switch开关点击弹出确认框时,状态先改变,点击确认/取消失效,怎么解决?)

概述:

el-switch 表示两种相互对立的状态间的切换,多用于触发「开/关」。

常见用法:

1、绑定v-model到一个Boolean类型的变量。可以使用active-color属性与inactive-color属性来设置开关的背景色。

2、使用active-text属性与inactive-text属性来设置开关的文字描述。

3、设置active-valueinactive-value属性,接受Boolean, StringNumber类型的值。

复制代码
//默认绑定Boolean类型的变量
<el-switch v-model="value"></el-switch>

//设置颜色
<el-switch v-model="value" active-color="#13ce66" inactive-color="#ff4949"></el-switch>

//设置显示文字
<el-switch v-model="boolValue" active-text="启用" inactive-text="关闭"></el-switch>

//默认绑定String类型的变量
<el-switch v-model="value2" active-value="male" inactive-value="femael"></el-switch>

//绑定Number类型
<el-switch v-model="value3" :active-value="1" :inactive-value="0"></el-switch>

//禁用
<el-switch v-model="value" disabled></el-switch>

//绑定事件
<el-switch v-model="value" @change="switchChange"></el-switch>

<script>
  export default {
    data() {
      return {
        value: true,
        value2: 'male',
        value3: 0,
      }
    },
     methods: {
        switchChange() {
          console.log(this.value);
      }
    }
  };
</script>

拓展问题:

element中el-switch开关点击弹出确认框时,状态先改变,点击确认/取消失效,怎么解决?

**原因:**v-model的数据双向绑定原理,点击开关时状态就已实时改变

解决方案:

只需将v-model改成:value="",再手动赋值即可

相关推荐
紫_龙1 分钟前
最新版vue3+TypeScript开发入门到实战教程之组件通信之二
前端·javascript·typescript
英俊潇洒美少年7 分钟前
Vue3 完整渲染流程(从 createApp → mount → update → unmount)
前端·javascript·vue.js
前端Hardy13 分钟前
Pinia 比 Vuex 好用 10 倍?Vue3 状态管理终于不折磨人了!(新手复制即用)
前端·javascript·vue.js
前端Hardy21 分钟前
Vue3 的 v-model 双向绑定,90% 的人都用错了?(附 2026 最新避坑指南)
前端·javascript·vue.js
前端Hardy21 分钟前
救命!Vue3 的 Composition API,居然能让我少写 80% 冗余代码?(新手也能直接抄)
前端·javascript·vue.js
Daiyaosei39 分钟前
紧急安全警报:Axios npm 包被投毒事件详解与防护指南
前端·javascript·安全
王霸天1 小时前
🚨 还在用 rem) 做大屏适配?用 vfit.js 一键搞定,告别改稿8版的噩梦!
前端·vue.js·数据可视化
Beginner x_u2 小时前
前端八股整理|JavaScript|高频小题 01
开发语言·前端·javascript
Mr Xu_2 小时前
Vue3 + Leaflet实战:深入解析MarkerCluster点位聚合插件的使用与优化
前端·javascript·vue.js
源码宝2 小时前
使用 PHP(Laravel 8)+ Vue 2 + Element UI + MySQL 5.7开发一套医院不良事件系统的注意事项
vue.js·php·laravel