el-switch不能更改状态的原因

背景需求:使用el-switch做一个改变状态的操作,在职位库的列表中增加一个“设为优质职位”的操作,如果是优质职位,改字段isQuality的值为1,反之为0。

 

问题描述:数据库中的isQuality字段的值为1,但是在前端打印出来的时候是0,对应不上。

 

代码如下:

<el-table-column label="设为优质职位" width="160" align="center">
    <template slot-scope="scope">
        <el-switch
            @change="changeIsQuality(scope.row)"
            v-model="scope.row.isQuality"
            active-value="1"
            inactive-value="0">
        </el-switch>
    </template>
</el-table-column>

代码解析:

value / v-model

绑定值

boolean / string / number

active-value

switch 打开时的值

boolean / string / number

true

inactive-value

switch 关闭时的值

boolean / string / number

false

事件名称

说明

回调参数

change

switch 状态发生变化时的回调函数

新状态的值

scope.row代表当前行的数据

解决方案:

<el-table-column label="设为优质职位" width="160" align="center">
    <template slot-scope="scope">
        <el-switch
            @change="changeIsQuality(scope.row)"
            v-model="scope.row.isQuality"
            :active-value="1"
            :inactive-value="0">
        </el-switch>
    </template>
</el-table-column>

:inactive-value="0"

:active-value="1"

看到区别了吗?就是加没加冒号

原因:

vue el-switch 绑定数值时要用

<el-switch v-model="value"
     :active-value="1"
     :inactive-value="0"
     active-color="#13ce66" 
     inactive-color="#ff4949">
</el-switch>

vue el-switch 绑定String时要用

<el-switch v-model="value"
     active-value="1"
     inactive-value="0"
     active-color="#13ce66" 
     inactive-color="#ff4949">
</el-switch>

  • 12
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值