vue + elementui 全局Loading效果

注:在request请求和响应封装的文件里引入loading,发请求时打开loading,响应时关闭loading,这样每个接口调用时都会有loading效果

(1) 首先确保项目中安装了element-ui这个依赖包

bash 复制代码
npm i element-ui -S

(2)引入Loading

javascript 复制代码
import { Loading } from 'element-ui'

(3)使用

javascript 复制代码
let globalLoading   // 定义loading
javascript 复制代码
 // 添加loading效果
 globalLoading = Loading.service({
   lock: true,
   text: '加载中...',
   background: 'rgba(0, 0, 0, 0.7)'
 })
javascript 复制代码
globalLoading.close()  // 响应-关闭loading

完整代码如下:

javascript 复制代码
import axios from 'axios'
import { Loading } from 'element-ui'
import { Notification } from 'element-ui'
import { getToken } from '@/utils/auth'

// loading设置
let globalLoading

// 创建axios实例
const service = axios.create({
  // axios中请求配置有baseURL选项,表示请求URL公共部分
  baseURL: process.env.VUE_APP_BASE_API,
  // 超时
  timeout: 30000
})
// request拦截器
service.interceptors.request.use(config => {
  // 请求加loading
  globalLoading = Loading.service({
    lock: true,
    text: '加载中...',
    background: 'rgba(0, 0, 0, 0.7)'
  })

  // 是否需要设置 token
  const isToken = (config.headers || {}).isToken === false
  if (getToken() && !isToken) {
    config.headers['Authorization'] = 'Bearer ' + getToken() // 让每个请求携带自定义token 请根据实际情况自行修改
  }

  return config
}, error => {
    console.log(error)
    Promise.reject(error)
})

// 响应拦截器
service.interceptors.response.use(res => {
    globalLoading.close()  // 响应-关闭loading

    // 未设置状态码则默认成功状态
    const code = res.data.code || 200;
    // 获取错误信息
    const msg = res.data.msg

    if(code==200 || code == 201 || code == 202 ){
      return res.data;
    } else if (code !== 200) {
      Notification.error({
        title: msg
      })
      return Promise.reject('error')
    } else {
      return res.data
    }
  },
  error => {
    console.log('err' + error)
    return Promise.reject(error)
  }
)

export default service
相关推荐
VX:Fegn089514 小时前
计算机毕业设计|基于springboot + vue手办商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
qq_5703985714 小时前
流式接口数据解析
前端·javascript·vue.js
坐吃山猪14 小时前
Electron入门示例
前端·javascript·electron
那些免费的砖14 小时前
Isle-Editor (岛屿编辑器) - 免费开源 Web 富文本编辑器,也支持 Notion 块编辑、MarkDown 语法,官方支持 Vue3 开箱即用
前端·编辑器·notion
꒰ঌ小武໒꒱14 小时前
Trae CN IDE 使用教程
前端·python·编辑器
灵魂学者14 小时前
Vue3.x —— router 路由配置
服务器·前端·vue.js·路由
by__csdn14 小时前
Ajax与Axios终极对比指南全方位对比解析
前端·javascript·ajax·okhttp·typescript·vue·restful
khatung14 小时前
借助Electron打通平台与用户通知(macOS系统)
前端·javascript·vscode·react.js·macos·electron·前端框架
VX:Fegn089514 小时前
计算机毕业设计|基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
by__csdn14 小时前
Vue3+Axios终极封装指南
前端·javascript·vue.js·http·ajax·typescript·vue