zj-element
Version:
基于ElementUI的VUE组件——Жидзин(Zidjin)系列组件库。
72 lines (66 loc) • 3.18 kB
JavaScript
/** x-request-config V1.0 自动请求接口信息的动作 20230215 by Sieyoo, 赵向明 */
import axios from 'axios';
const XRequestAction = function() {};
/**
* function format 对Date的扩展,将 Date 转化为指定格式的String
* @param {object} config 请求配置。可用的属性有:{url, method, headers, nodeData, nodeStatus, nodeStatusValue}
* @param {object} param 请求接口中需要附带上的参数
* @desc 符号定义
* @return {Promise} 请求接口的返回信息
* @example 例子:
* config = {
* url: '/api/enroll_edit/{{id}}',
* method: 'PUT',
* headers: { Authorization: localStorage.getItem('token') },
* nodeStatus: 'err',
* nodeStatusValue: 0,
* };
*/
XRequestAction.request = function(config, param={}){
// console.log("getCurrentSelect 2:", config, param,);
// let newParam = {};
// 过滤掉空信息,有BUG
// for(const key in param){
// if(param[key] === null) continue;
// newParam[key] = param[key];
// }
return new Promise((resolve, reject, prarmKey='data') => {
let method = (config.method && config.method.toUpperCase()) || 'GET';
prarmKey = method === 'POST' || method === 'PUT' || method === 'PATCH' ? 'data' : 'params';
// console.log("prarmKey", prarmKey)
axios({
url: config.url,
method: config.method || 'GET',
[prarmKey]: param, // 是即将与请求一起发送的 URL 参数
timeout: 15000,
headers: {
'content-type': 'application/json',
...config.headers
},
}).then(res => {
// console.log("requestAction: res:", res)
if (res.status === 200) {
if (res.data[config.nodeStatus || 'err'] === (config.nodeStatusValue || 0)) {
// console.log('requestAction: success:', res);
// console.log('requestAction: success 2:', config.nodeData);
if(config.nodeData === undefined)
config.nodeData = 'data';
let tt = config.nodeData.split('.');
let result = tt.length === 1 && tt[0] ? res.data[config.nodeData] : tt.length === 2 && res.data && res.data[tt[0]] && res.data[tt[0]][tt[1]] ? res.data[tt[0]][tt[1]] : res.data;
// console.log("result", result)
resolve(result || {});
} else {
// this.$message({ message: res.data && res.data.msg, type: 'warning' });
// console.log('服务器连接正确,但返回接口或参数错误:', res.data.msg ? res.data.msg : res);
reject(res.data.data ? res.data.data : res.data, res);
}
} else {
reject(res.data.data ? res.data.data : res.data, res);
}
}).catch(err => {
// console.log('网络地址没有响应或请求失败 config:', config, err);
reject(err.data, res);
});
});
}
export default XRequestAction