@caxa-form/core
Version:
vue动态表单,助你轻松搞定表单|form-create is a form generation component that can generate dynamic rendering, data collection, verification and submission functions through JSON. Supports 3 UI frameworks, and supports the generation of any Vue components. Built-in 20
73 lines (58 loc) • 1.77 kB
JavaScript
// https://github.com/ElemeFE/element/blob/dev/packages/upload/src/ajax.js
function getError(action, option, xhr) {
const msg = `fail to ${action} ${xhr.status}'`;
const err = new Error(msg);
err.status = xhr.status;
err.url = action;
return err;
}
function getBody(xhr) {
const text = xhr.responseText || xhr.response;
if (!text) {
return text;
}
try {
return JSON.parse(text);
} catch (e) {
return text;
}
}
export default function fetch(option) {
if (typeof XMLHttpRequest === 'undefined') {
return;
}
const xhr = new XMLHttpRequest();
const action = option.action;
xhr.onerror = function error(e) {
option.onError(e);
};
xhr.onload = function onload() {
if (xhr.status < 200 || xhr.status >= 300) {
return option.onError(getError(action, option, xhr), getBody(xhr));
}
option.onSuccess(getBody(xhr));
};
xhr.open(option.method || 'get', action, true);
let formData;
if (option.data) {
if ((option.dataType || '').toLowerCase() !== 'json') {
formData = new FormData();
Object.keys(option.data).map(key => {
formData.append(key, option.data[key]);
});
} else {
formData = JSON.stringify(option.data);
xhr.setRequestHeader('content-type', 'application/json');
}
}
if (option.withCredentials && 'withCredentials' in xhr) {
xhr.withCredentials = true;
}
const headers = option.headers || {};
Object.keys(headers).forEach(item => {
if (headers[item] !== null) {
xhr.setRequestHeader(item, headers[item]);
}
});
xhr.send(formData);
}