- 需求:在项目开发过程中通常会给请求加loading,每次发请求单独加loading费事费力。
- 思路:用h5做手机端项目,业务简单,统一封装loading,由于vue组件化开发,通常是用ajax封装后的axios插件进行,在请求拦截里面可以加loading,接口返回拦截器里面关闭loading。
- 具体实现过程
1、每个接口的loading做成可配置化,如果模块的实际业务需要自己加loading,可以在请求方法中配不需要统一loading,hideloading属性。在请求拦截器,interceptors.request中如果不隐藏loading,就打开全局loading。
2、接口返回的拦截器,interceptors.response中关闭loading。 - 注意:由于h5手机端使用的是vant组件,loading和提示语都是轻提示,实现起来比较容易实现。
- 参看代码如下:
import axios from 'axios'
import { Toast, Dialog } from 'vant'
import router from '@/router'
import { Tips } from '@/utils/index'
import configs from "@/config";
// create an axios instance
const service = axios.create({
baseURL: configs.HTTP_URL,
withCredentials: true, // send cookies when cross-domain requests
timeout: 50000 // 等待时间
})
console.log(configs)
// request拦截器 request interceptor
service.interceptors.request.use(
config => {
// 不传递默认开启loading
if (!config.hideloading) {
// loading
Tips.loading(config.message)
}
if (localStorage.getItem('gy_h5_access_token')) {
config.headers['access_token'] = localStorage.getItem('gy_h5_access_token')
}
config.headers['x-service-id'] = '123'
return config
},
error => {
// do something with request error
console.log(error) // for debug
return Promise.reject(error)
}
)
// respone拦截器
service.interceptors.response.use(
response => {
Toast.clear()
const res = response.data
if (res.status && res.status !== 200) {
Tips.error(res.msg)
return Promise.reject(res || 'error')
} else {
if (res.code === 200) {
return Promise.resolve(res.data)
} else {
Tips.error(res.msg)
return Promise.reject(res || 'error')
}
}
},
error => {
Toast.clear()
if (error.response.status === 401) {
Dialog({ message: '登录过期,请重新登录' }).then(() => {
localStorage.removeItem('gy_h5_access_token')
if (configs.otherUrl.ifsUrl) {
window.location.href = configs.otherUrl.ifsUrl + '/login'
} else {
router.replace({ name: 'NotFound' })
}
})
} else {
console.log(error,'error')
Tips.error(error.response.data.message)
}
return Promise.reject(error)
}
)
export default service
文章来源地址https://www.toymoban.com/news/detail-818907.html
文章来源:https://www.toymoban.com/news/detail-818907.html
到了这里,关于vue请求拦截统一给所有请求加loading的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!