element UI的Loading服务调用无法停止

发布于 2022-09-06 08:40:36 字数 1345 浏览 17 评论 0

首先是来自element的官方解释

clipboard.png

当我以服务的方式调用loading的时候,没问题。
代码如下:

axios.interceptors.request.use((config) => {
  // 遮蔽式请求框
  loading = Loading.service({fullscreen: true, text: '拼命加载中....'})
 // , target: 'div.tableList, div.right_out'
  return config
}, (error) => {
   console.log('发送失败')
  Notification.error({
    title: '发送失败',
    message: error.message
  })
  loading.close()
  return Promise.reject(error)
})

// 返回状态判断
axios.interceptors.response.use((response) => {
  console.log('请求成功')
  if (response.status === 200) {
    if (response.data.code === -1) {
      Notification.error({
        title: '请求异常',
        message: response.data.message
      })
    }
    loading.close()
    return response
  }
}, (err) => {
  console.log('请求失败')
  loading.close()
  return Promise.reject(err)
})

此时loading.close()可以正常的结束loading。但是如果给loading指定覆盖的target的时候

loading = Loading.service({fullscreen: true, text: '拼命加载中....', target: 'div.tableList, div.right_out'})
 // target    Loading 需要覆盖的 DOM 节点。可传入一个 DOM 对象或字符串;若传入字符串,则会将其作为参数传入 document.querySelector以获取到对应 DOM 节点    默认值:document.body

此时loading.close()无法关闭loading。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

诗笺 2022-09-13 08:40:36

指定target时 每次返回的都是单独的实例 需要自己建列表手动维护

初熏 2022-09-13 08:40:36

在拦截起调用新的Loading之前检测是否有实例存在,如果有则调用close()方法关闭实例,然后再调用新的Loading

loading && loading.close()

或者可以试试如果实例存在,则不创建新的实例

灼疼热情 2022-09-13 08:40:36

if (loadinginstace) {

loadinginstace.close()

}图片描述

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文