UNPKG

zj-element

Version:

基于ElementUI的VUE组件——Жидзин(Zidjin)系列组件库。

72 lines (66 loc) 3.18 kB
/** 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