vue项目中api接口管理总结
发布时间:2020-12-17 02:20:03 所属栏目:百科 来源:网络整理
导读:默认vue项目中已经使用vue-cli生成,安装axios,基于element-ui开发,axiosconfig目录和api目录是同级,主要记录配置的相关。 1. 在axiosconfig目录下的axiosConfig.js // 配置接口地址 axios.defaults.baseURL = '' var loadingInstance // POST传参序列化(
默认vue项目中已经使用vue-cli生成,安装axios,基于element-ui开发,axiosconfig目录和api目录是同级,主要记录配置的相关。 1. 在axiosconfig目录下的axiosConfig.js// 配置接口地址
axios.defaults.baseURL = '' var loadingInstance // POST传参序列化(添加请求拦截器) axios.interceptors.request.use( config => { loadingInstance = Loading.service({ lock: true,text: '数据加载中,请稍后...',spinner: 'el-icon-loading',background: 'rgba(0,0.7)' }) if (config.method === 'post') { config.data = qs.stringify(config.data) } return config },err => { loadingInstance.close() Message.error('请求错误') return Promise.reject(err) } ) // 返回状态判断(添加响应拦截器) axios.interceptors.response.use( res => { if (res.data.code === 200) { loadingInstance.close() return res } else { loadingInstance.close() Message.error(res.data.msg) } },err => { loadingInstance.close() Message.error('请求失败,请稍后再试') return Promise.reject(err) } ) // 发送请求 export function post (url,params) { return new Promise((resolve,reject) => { axios .post(url,params) .then( res => { resolve(res.data) },err => { reject(err.data) } ) .catch(err => { reject(err.data) }) }) } export function get (url,reject) => { axios .get(url,{ params: params }) .then(res => { resolve(res.data) }) .catch(err => { reject(err.data) }) }) } 2. 在api目录下的index.js,api1.js,api2.js3. main.js 配置4. 在组件中使用 {
console.log(res)
})
}
注册组件中
doRegist() {
let params={}
this.$api.api2.regist(params).then(res => {
console.log(res)
})
}
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |