iview爬坑之旅——Modal点击‘确定’按钮时弹框自动关闭问题

最近在做Angular项目到Vue项目重构迁移,之前Angular用的UI框架是NG-ZORRO,Vue现在用的是Iview; 但是当用Iview-modal 做表单或者条件校验时遇到了一个问题,当校验不通过时,点击确定,当校验不通过时,弹框也自动关闭了;

解决方案

方案一 (自用)

利用Modal的slot,自定义写底部按钮,这样就可以避开组件内置的 @On-ok, @on-cancel;在按钮点击事件里面去做数据的验证,通过v-model控制模态框的显示与隐藏。

 <!--解决弹框自动关闭-->
 <div slot="footer">
   <Button type="text" @click="handleOnCancel">取消</Button>
   <Button type="primary" @click="handleConfirmClick">确定</Button>						
 </div>

这种情况需要手动关闭Modal,注意点击右上方关闭按钮,和点击遮罩层关闭之后的情况;
在这里插入图片描述

方案二

给Modal添加属性loading后,点击确定按钮后,对话框不会自动消失,会进入等待状态,并显示 loading 状态,需要手动关闭对话框,常用于表单提交;


this.$refs[name].validate(async (valid) => {
   if (valid) {
     this.loading = false 
     let res= await this.fetchGet('***', {})
     if (res == null) {
       this.$Message.error('*****')
       this.loading = true 
     } else { 
       this.model = false
       this.loading = true
     } 
   } else {
     this.$Message.error('表单验证失败!');
    }
})
参考资料
  1. Github关于Modal自动关闭的讨论
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值