Vue2 elementui2 中 el-switch 实现先判断改变状态

Vue2 elementui2 中 el-switch 实现先判断改变状态

最后附上完整组件代码

elementui 中 el-switch在使用时,直接使用change 事件,每次点击 时都先改变switch 状态,然后再处理业务逻辑,体验上不优好。根据产品要求需要先处理业务逻辑再改变switch状态。

具体实现: 给switch组件设置disable (必须设置), 禁用掉操作,然后给switch 添加上@click.native 或 @click.native.prevent 事件

  • 添加@click.native.prevent方法达到目的,

    • 给vue组件绑定事件时候,必须加上native ,否则会认为监听的是来自Item组件自定义的事件
    • prevent 是用来阻止默认的 ,相当于原生的event.preventDefault()
  • 与此同时需要打开disabled属性

    • 是因为不加disabled会出现调用两次的非理想状态

      复制代码
        <el-table-column 
              label="渠道状态" 
              prop="state" 
              width="80">
          <template slot-scope="{ row }">
            <el-switch 
                  v-model="row.state" 
                  :active-value="1" 
                  :inactive-value="2" 
                  @click.native="handleSwitchange(row.state, row)" 
                  disabled 
              />
          </template>
        </el-table-column>

js 代码

复制代码
handleSwitchange(e,row) {
      const msg = e === 1 ? `确定关闭渠道 ${row.channelId}吗?` : `确定开启渠道 ${row.channelId}吗?`
      this.$modal.confirm(msg).then(() => {
        // 处理业务逻辑
        row.state = e === 1 ?2:1
      }).then(() => {
        // 成功时执行
        row.state = e === 1 ?2:1
      }).catch(() => {
          //取消或失败时处理
      });
    }

最后修改switch 的 disabled样式问题

• 保证修改完后同样式正常无异

• 在设置disabled后开关会有鼠标禁用的样式及透明度的变化,需要我们做修改。 这里不建议直接在使用style 中修改避免污染其他界面样式,建议使用深度选择器deep进行修改

复制代码
<style lang="scss" scoped>
/* 深度选择器进行样式穿透 */
::v-deep{    

/* 修改elementUI-switch组件 disabled样式 */
 .el-switch.is-disabled {
   opacity: 1;
  }    

  /*修改鼠标悬停显示状态*/
 .el-switch.is-disabled .el-switch__core,
 .el-switch.is-disabled .el-switch__label {
   cursor: pointer !important; /*这里修改成小手状态*/
 }
}

</style>

不使用深度选择器,这里需要去掉scoped

复制代码
<style lang="scss" >


/* 修改elementUI-switch组件 disabled样式 */
 .el-switch.is-disabled {
   opacity: 1;
  }    

  /*修改鼠标悬停显示状态*/
 .el-switch.is-disabled .el-switch__core,
 .el-switch.is-disabled .el-switch__label {
   cursor: pointer !important; /*这里修改成小手状态*/
 }

</style>

完整组件代码:

使用:

复制代码
 <switch-plus v-model="row.state" :active-value="1" :inactive-value="2" @onChange="handleSwitchange(row.state, row)" />

switchplus.vue:

复制代码
<template>
  <el-switch v-bind="$attrs" @click.native.prevent="$emit('onChange')" disabled />
</template>
<script>
export default {
  name: 'SwitchPlus',

  data() {
    return {
    }
  },
  mounted() {
  },
  methods: {
  },
}
</script>
<style lang="scss" scoped>

//直接写类名(不带deep) 
.el-switch.is-disabled {
  opacity: 1 !important;
  // 用 ::v-deep 包起来
  ::v-deep {
    .el-switch__core , .el-switch__label{
      pointer-events: auto !important;
      cursor: pointer !important;
    }
  
  }
}
</style>
相关推荐
ConardLi9 分钟前
啊?我刚开源的 Skills 已经 7K Star 了?!
前端·人工智能·后端
糯米团子74916 分钟前
javascript高频知识点
开发语言·前端·javascript
道友可好27 分钟前
Git Worktree:一个仓库,多个分身
前端·后端·程序员
道友可好35 分钟前
AI 写代码太快了,快到你对齐不了它
前端·人工智能
无风听海1 小时前
Bearer Token 权威指南:从原理到生产级安全实践
前端·javascript·安全
jerrywus1 小时前
别只换模型!Claude Opus 4.8 努力控制 + Fast模式,真实能省钱3倍
前端·agent·claude
riuphan1 小时前
JavaScript 类型判断完全指南
前端·javascript
Hilaku1 小时前
前端工程师最终会变成 AI工程师?
前端·javascript·程序员
yeflx1 小时前
Ubuntu22.04重装显卡驱动
前端·chrome
小二·1 小时前
Prompt Engineering 高级技巧:CoT/ToT/ReAct 等进阶方法论实战
前端·react.js·prompt