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="",再手动赋值即可

相关推荐
Moonbeam Community1 分钟前
应用爆发,DeFi先行
javascript·ide·web3·区块链·polkadot
2301_796512524 分钟前
使用状态管理、持久化存储或者利用现有的库来辅助React Native鸿蒙跨平台开发开发一个允许用户撤销删除的操作
javascript·react native·react.js
前端不太难21 分钟前
RN Navigation vs Vue Router 的架构对比
javascript·vue.js·架构
小白学大数据26 分钟前
Python 爬虫如何分析并模拟 JS 动态请求
开发语言·javascript·爬虫·python
2301_7965125226 分钟前
React Native鸿蒙跨平台开发包含输入收入金额、选择收入类别、记录备注和日期等功能,实战react-native-paper组件
javascript·react native·react.js
Miketutu28 分钟前
[特殊字符] uni-app App 端实现文件上传功能(基于 xe-upload 插件)
前端·vue.js·uni-app
焚 城29 分钟前
uniapp 各种文件预览实现
vue.js·uni-app·html
巴拉巴拉~~32 分钟前
Flutter 通用表单输入组件 CustomInputWidget:校验 + 样式 + 交互一键适配
javascript·flutter·交互
San30.34 分钟前
现代前端工程化实战:从 Vite 到 Vue Router 的构建之旅
前端·javascript·vue.js
sg_knight34 分钟前
模块热替换 (HMR):前端开发的“魔法”与提速秘籍
前端·javascript·vue·浏览器·web·模块化·hmr