【VUE异常】el-popconfirm失效,@confirm事件不生效,点击没有任何反应,刷新页面才能点击

简介: 【VUE异常】el-popconfirm失效,@confirm事件不生效,点击没有任何反应,刷新页面才能点击

一、背景描述

项目中遇到一个奇怪的问题,我使用了 el-popconfirm 组件,项目基于VUE,el-popconfirm 包裹住的按钮,操作列有好几个按钮选项,点击其中任何一处按钮之后,再次打开另外的一个 el-popconfirm 包裹住的按钮点击没有任何的反应,刷新浏览器之后才能点击触发相应的事件。当我把 v-if 删除之后,所有按钮都可以正常操作。加上 v-if 来进行显示控制,就需要刷浏览器之后才能触发相应的事件。

如果下图所示:

二、原因分析

因为我在按钮中使用了 v-if 来进行显示控制,当我在 el-popconfirm 组件上直接使用 v-if=“” 的时候,就会出现这个问题,问题出现在 v-if 与 el-popconfirm 结合。

三、解决方案

3.1 方案一:使用@onConfirm

<el-popconfirm
  title="是否忽略此次警告?"
  @onConfirm="test(scope.row)"
  v-if="row.status === 0"
  >
</el-popconfirm>

注意,此方案不是适合所有情况。有人可能还是不起作用。请继续往下看

3.2 方案二:@confirm与@onConfirm同时使用

单独使用 @confirm 或者 @onConfirm 都没有效果,折中方式如下:

<el-popconfirm
  title="是否忽略此次警告?"
  @confirm="test(scope.row)"
  @onConfirm="test(scope.row)"
  v-if="row.status === 0"
  >
</el-popconfirm>

注意,此方案不是适合所有情况。有人可能还是不起作用。

3.3 方案三:el-popconfirm 标签外包裹一层标签

比如在在 el-popconfirm 标签外 加一层 span 标签,然后把 v-if 语句写在 span 标签上

<span v-if="row.status === 0">
  <el-popconfirm
    title="是否忽略此次警告?"
    @confirm="test(scope.row)"
    @onConfirm="test(scope.row)"
    >
  </el-popconfirm>
</span>

终极解决方案,这个可能适合多数人,不过最后的样式需要微调一下。

本文完结!


相关文章
|
1天前
|
缓存 JavaScript
vue学习(12)计算属性
vue学习(12)计算属性
11 3
|
1天前
|
JavaScript
vue学习(10)事件修饰符
vue学习(10)事件修饰符
10 3
|
1天前
|
缓存 JavaScript
vue学习(12)计算属性
vue学习(12)计算属性
9 2
|
1天前
|
JavaScript
vue学习(11)键盘事件
vue学习(11)键盘事件
8 2
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1036 0
|
4天前
|
JavaScript
vue学习(3)模板语法
vue学习(3)模板语法
34 11
|
9天前
|
JavaScript
vue中使用@scroll不生效的问题
vue中使用@scroll不生效的问题
|
4天前
|
存储 JavaScript 前端开发
vue学习(2)
vue学习(2)
194 65
|
4天前
|
JavaScript 算法 前端开发
vue学习(1)
vue学习(1)
194 62
|
3天前
|
JavaScript
vue学习(4)数据绑定
vue学习(4)数据绑定
16 10