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>
相关推荐
倾颜4 小时前
从 textarea 到 AI 输入框:用 Tiptap 实现 / 命令、@ 引用和结构化请求
前端·langchain·next.js
kyriewen5 小时前
程序员连夜带团队跑路,省了23万:这AI太贵,真的用不起了
前端·javascript·openai
kyriewen6 小时前
你写的代码没有测试,就像出门不锁门——Jest + Testing Library 从入门到不慌
前端·单元测试·jest
yuzhiboyouye7 小时前
web前端英语面试
前端·面试·状态模式
canonical_entropy8 小时前
下一代低代码渲染框架 nop-chaos-flux 的设计原则
前端·低代码·前端框架
东方小月8 小时前
5分钟搞懂Harness Engineering(驾驭工程):从提示词到AI Agent的进化之路
前端·后端·架构
我叫黑大帅8 小时前
为什么需要 @types/react?解决“无法找到模块 react 的声明文件”报错
前端·javascript·面试
之歆8 小时前
DAY_21JavaScript 深度解析:数组(Array)与函数(Function)(一)
前端·javascript
XinZong9 小时前
【AI社交】基于OpenClaw自研轻量化AI社交平台实战
前端
Le_ee9 小时前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php