/** * 响应拦截 * @param {Object} http */ module.exports = (vm) => { uni.$u.http.interceptors.response.use( (response) => { /* 对响应成功做点什么 可使用async await 做异步操作*/ const data = response.data; // 自定义参数 const custom = response.config?.custom; if (data.errCode !== 0 && data.code !== 0) { // 服务端返回的状态码不等于200,则reject() // 如果没有显式定义custom的toast参数为false的话,默认对报错进行toast弹出提示 // if (custom.toast !== false) { // uni.$u.toast(data.message) // } // 如果需要catch返回,则进行reject // if (custom?.catch) { console.error('http catch rejected', data) return Promise.reject(data); // } else { // // 否则返回一个pending中的promise // return new Promise(() => { }) // } } return data.data || {}; }, (response) => { /* 对响应错误做点什么 (statusCode !== 200)*/ return Promise.reject(response); }, ); };