vue+el使用this.$confirm,不能阻断代码往下执行的解决

 更新时间:2022年09月23日 15:01:32   作者:老贼大魔王  
这篇文章主要介绍了vue+el使用this.$confirm,不能阻断代码往下执行的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue+el使用this.$confirm不能阻断代码往下执行

在vue+element ui的前端框架中使用el的confirm弹窗,遇到一个问题,就是连续多个弹窗提示一些信息,要是点击确定继续向下执行,点击取消就退出整个方法。

这时发现当代码执行到this.$confirm弹窗时,弹出弹窗后,继续执行了弹窗之后的代码,没有等到弹窗点击确定或是取消之后再执行。

具体解决

其实解决办法也很简单,因为this.$confirm也是一个promise方法,所以可以使用es6中的await等到返回结果。

await 表达式会暂停当前 async function 的执行,等待 Promise 处理完成。

......
if(await this.$confirm('是否保存修改?', '确认信息', {
   distinguishCancelAndClose: true,
   confirmButtonText: '保存',
   cancelButtonText: '取消'
 }).catch(() => {}) !== 'confirm') {
    return
}
// 点击取消退出方法,点击保存则继续往下执行
// 若没有await,在弹出弹窗的同时就会接着往下执行
this.doSaveInfo()
......

后记

看官方文档学习一定要看仔细,看明白。认真学习promise和await。

使用this.$confirm换行显示提示信息

在写一个简单的按钮点击确认框信息的时候,发现换行不能用\n。用了< br>发现也是字符串的输出形式

去查了下发现需要使用$createElement来创建

这里我需要显示两行信息

代码如下

creatNew(){
 const h = this.$createElement
        this.$confirm('提示', {
          title: '提示',
          message: h('div', [
            h('p', '新建会导致之前设置失效'),
            h('p', '是否继续新建?')
          ]),
          confirmButtonText: '确定',
          cancelButtonText: '取消'
        }).then(() => {
        ....//调用新建方法
        }).catch(()=>({}))//不要忘记catch
        //最后可以.finally(()=>({}))
        }

解释

★h('div')就表示创建一个div标签,

★如果写成h('div',{class:'...'})就可以定义class,如:

 h('i', { class: 'el-icon-question' })

★如果写成下面的,则可以定义props。(以element的弹出框el-tooltip为例)

h('el-tooltip',{props:{
                    content: (function() {
                      return '弹出信息'
                      })(),
                    placement: 'top'
                    }})

★包含关系用h('div',[...]),如div中包含两个p标签:(可以继续嵌套)

h('div', [
            h('p', '第一个p'),
            h('p', '第二个p')
          ])

简单介绍到这里吧~ 

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 解析vue 3.0 使用axios库发起 post get 的配置过程

    解析vue 3.0 使用axios库发起 post get 的配置过程

    get post 请求开发中最普通最常见的请求方式但是在vue中如何实现呢 这里记录一下配置过程,对vue 使用axios发起 post get配置过程感兴趣的朋友一起看看吧
    2022-05-05
  • vue实现带缩略图的轮播图效果

    vue实现带缩略图的轮播图效果

    这篇文章主要为大家详细介绍了如何使用vue实现带缩略图的轮播图效果,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的可以参考下
    2024-02-02
  • 深入解析Vue的自定义指令

    深入解析Vue的自定义指令

    这篇文章主要介绍了深入解析Vue的自定义指令,自定义指令主要是为了重用涉及普通元素的底层 DOM 访问的逻辑,一个自定义指令由一个包含类似组件生命周期钩子的对象来定义,需要的朋友可以参考下
    2023-05-05
  • 详解如何使用vue实现页面访问拦截

    详解如何使用vue实现页面访问拦截

    这篇文章主要为大家详细介绍了如何使用vue实现页面访问拦截功能,文中的示例代码讲解详细,具有一定的参考价值,需要的可以了解一下
    2023-08-08
  • 基于Vue生产环境部署详解

    基于Vue生产环境部署详解

    下面小编就为大家带来一篇基于Vue生产环境部署详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • Vuex进行Echarts数据页面初始化后如何更新dom

    Vuex进行Echarts数据页面初始化后如何更新dom

    这篇文章主要为大家详细介绍了使用Vuex做Echarts数据时,当页面初始化后如何更新dom,文中的示例代码讲解详细,有需要的小伙伴可以跟随小编一起学习一下
    2023-11-11
  • Vue3+ts+setup getCurrentInstance使用时遇到的问题以及解决办法

    Vue3+ts+setup getCurrentInstance使用时遇到的问题以及解决办法

    getCurrentInstance方法用于获取当前组件实例,仅在setup和生命周期中起作用,下面这篇文章主要给大家介绍了关于Vue3+ts+setup getCurrentInstance使用时遇到的问题以及解决办法,需要的朋友可以参考下
    2022-08-08
  • 解决vue项目本地启动时无法携带cookie的问题

    解决vue项目本地启动时无法携带cookie的问题

    这篇文章主要介绍了解决vue项目本地启动时无法携带cookie,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Vue如何利用flex布局实现TV端城市列表功能

    Vue如何利用flex布局实现TV端城市列表功能

    用vue开发了三四个组件了,都是H5的,现在来看看PC是如何玩转组件的,下面这篇文章主要给大家介绍了关于Vue如何利用flex布局实现TV端城市列表功能的相关资料,需要的朋友可以参考下
    2023-01-01
  • vue+mockjs模拟数据实现前后端分离开发的实例代码

    vue+mockjs模拟数据实现前后端分离开发的实例代码

    本篇文章主要介绍了vue+mockjs模拟数据实现前后端分离开发的实例代码,具有一定的参考价值,有兴趣的可以了解一下
    2017-08-08

最新评论