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

 更新时间:2026年03月31日 09:05:10   作者:蜡台  
本文给大家介绍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>
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>

到此这篇关于Vue2 elementui2 中 el-switch 实现先判断改变状态的文章就介绍到这了,更多相关Vue elementui el-switch判断改变状态内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue如何根据角色获取菜单动态添加路由

    Vue如何根据角色获取菜单动态添加路由

    这篇文章主要介绍了Vue如何根据角色获取菜单动态添加路由,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • Vue中的插槽Slot技术详解

    Vue中的插槽Slot技术详解

    插槽(Slot)技术是一种用于组件化开发的重要技术,允许我们在组件中定义一些占位符,在Vue中,插槽的使用方式可以分为三种:默认插槽、具名插槽和作用域插槽,下面我们就来看看这三种方式的具体使用吧
    2023-09-09
  • Vue悬浮窗和聚焦登录组件功能实现

    Vue悬浮窗和聚焦登录组件功能实现

    这篇文章主要介绍了Vue悬浮窗和聚焦登录组件经验总结,​ 本文整理了实现悬浮窗以及聚焦登录组件的功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-11-11
  • Vue使用el-table实现表格跨页多选

    Vue使用el-table实现表格跨页多选

    在我们日常项目开发中,经常会有表格跨页多选的需求,接下来让我们用 el-table示例一步步来实现这个需求,文中有详细的代码讲解,对我们的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-08-08
  • 详解vue中组件参数

    详解vue中组件参数

    这篇文章主要介绍了vue中组件参数,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • vue与TypeScript集成配置最简教程(推荐)

    vue与TypeScript集成配置最简教程(推荐)

    本篇文章主要介绍了vue与TypeScript集成配置最简教程(推荐),具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10
  • vue+echart实现双柱状图

    vue+echart实现双柱状图

    这篇文章主要为大家详细介绍了vue+echart实现双柱状图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • Vue组件封装方案实现浅析

    Vue组件封装方案实现浅析

    这篇文章主要介绍了Vue组件封装方案实现,我们将从分析组件封装的优势开始,然后依次介绍 vue.js 的基本概念,以及如何创建、封装和使用自定义组件
    2023-03-03
  • Vue实现单行删除与批量删除

    Vue实现单行删除与批量删除

    这篇文章主要介绍了Vue实现单行删除与批量删除,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • vue实现评论列表功能

    vue实现评论列表功能

    本文通过实例代码给大家介绍了vue实现评论列表功能,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2019-10-10

最新评论