!65 [inula-request]<bugfix> 修复请求取消时 isCancel 判断错误的问题
Merge pull request !65 from 涂旭辉/master
This commit is contained in:
commit
c29ad294d5
|
@ -16,42 +16,33 @@
|
||||||
</div>
|
</div>
|
||||||
<script src="../../dist/bundle.js"></script>
|
<script src="../../dist/bundle.js"></script>
|
||||||
<script>
|
<script>
|
||||||
|
import inulaRequest from "../../index";
|
||||||
|
|
||||||
const sendRequestButton = document.getElementById('sendRequestButton');
|
const sendRequestButton = document.getElementById('sendRequestButton');
|
||||||
const cancelRequestButton = document.getElementById('cancelRequestButton');
|
const cancelRequestButton = document.getElementById('cancelRequestButton');
|
||||||
const message = document.getElementById('message');
|
const message = document.getElementById('message');
|
||||||
|
|
||||||
let cancelTokenSource;
|
let controller = new AbortController;
|
||||||
|
const signal = controller.signal;
|
||||||
|
|
||||||
sendRequestButton.addEventListener('click', function() {
|
sendRequestButton.addEventListener('click', function() {
|
||||||
message.innerHTML = '';
|
setInterval(function() {
|
||||||
cancelTokenSource = inulaRequest.CancelToken.source();
|
inulaRequest.get('http://localhost:3001/data', {
|
||||||
|
signal
|
||||||
inulaRequest.get('http://localhost:3001/data', {
|
}).then(function(response) {
|
||||||
cancelToken: cancelTokenSource.token
|
message.innerHTML = '请求成功: ' + JSON.stringify(response.data, null, 2);
|
||||||
}).then(function(response) {
|
}).catch(function(error) {
|
||||||
message.innerHTML = '请求成功: ' + JSON.stringify(response.data, null, 2);
|
if (inulaRequest.isCancel(error)) {
|
||||||
}).catch(function(error) {
|
message.innerHTML = '请求已被取消: ' + error.message;
|
||||||
message.innerHTML = JSON.stringify(error, null, 2);
|
} else {
|
||||||
});
|
message.innerHTML = '请求出错: ' + error.message;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}, 1000)
|
||||||
});
|
});
|
||||||
|
|
||||||
cancelRequestButton.addEventListener('click', function () {
|
cancelRequestButton.addEventListener('click', function () {
|
||||||
const CancelToken = inulaRequest.CancelToken;
|
controller.abort();
|
||||||
const source = CancelToken.source();
|
|
||||||
|
|
||||||
inulaRequest.get('http://localhost:3001/data', {
|
|
||||||
cancelToken: source.token
|
|
||||||
}).then(function(response) {
|
|
||||||
console.log(response.data);
|
|
||||||
}).catch(function(error) {
|
|
||||||
if (inulaRequest.isCancel(error)) {
|
|
||||||
message.innerHTML = '请求已被取消:' + error.message;
|
|
||||||
} else {
|
|
||||||
message.innerHTML = '请求出错:' + error.message;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
source.cancel('请求被用户取消。');
|
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
|
|
|
@ -17,7 +17,7 @@ import IrError from '../core/IrError';
|
||||||
import { IrRequestConfig } from '../types/interfaces';
|
import { IrRequestConfig } from '../types/interfaces';
|
||||||
|
|
||||||
class CancelError extends IrError {
|
class CancelError extends IrError {
|
||||||
constructor(message: string | undefined, config: IrRequestConfig, request?: any) {
|
constructor(message: string | undefined | null, config: IrRequestConfig, request?: any) {
|
||||||
const errorMessage = message || 'canceled';
|
const errorMessage = message || 'canceled';
|
||||||
super(errorMessage, (IrError as any).ERR_CANCELED, config, request);
|
super(errorMessage, (IrError as any).ERR_CANCELED, config, request);
|
||||||
this.name = 'CanceledError';
|
this.name = 'CanceledError';
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
// 检查是否为用户主动请求取消场景
|
// 检查是否为用户主动请求取消场景
|
||||||
function checkCancel(input: any): boolean {
|
function checkCancel(input: any): boolean {
|
||||||
return input.cancelFlag || false;
|
return input.name === 'CanceledError' || input.cancelFlag || false;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default checkCancel;
|
export default checkCancel;
|
||||||
|
|
|
@ -98,6 +98,7 @@ const errorTypes = [
|
||||||
'ERR_CANCELED',
|
'ERR_CANCELED',
|
||||||
'ERR_NOT_SUPPORT',
|
'ERR_NOT_SUPPORT',
|
||||||
'ERR_INVALID_URL',
|
'ERR_INVALID_URL',
|
||||||
|
'ERR_FETCH_FAILED',
|
||||||
];
|
];
|
||||||
|
|
||||||
const descriptors: PropertyDescriptorMap = errorTypes.reduce((acc, code) => {
|
const descriptors: PropertyDescriptorMap = errorTypes.reduce((acc, code) => {
|
||||||
|
|
|
@ -19,6 +19,7 @@ import { IrRequestConfig, IrResponse, Cancel } from '../types/interfaces';
|
||||||
import { Method, ResponseType } from '../types/types';
|
import { Method, ResponseType } from '../types/types';
|
||||||
import processUploadProgress from './processUploadProgress';
|
import processUploadProgress from './processUploadProgress';
|
||||||
import processDownloadProgress from './processDownloadProgress';
|
import processDownloadProgress from './processDownloadProgress';
|
||||||
|
import CancelError from '../cancel/CancelError';
|
||||||
|
|
||||||
export const fetchRequest = (config: IrRequestConfig): Promise<IrResponse> => {
|
export const fetchRequest = (config: IrRequestConfig): Promise<IrResponse> => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
|
@ -47,8 +48,9 @@ export const fetchRequest = (config: IrRequestConfig): Promise<IrResponse> => {
|
||||||
// 处理请求取消
|
// 处理请求取消
|
||||||
if (cancelToken) {
|
if (cancelToken) {
|
||||||
cancelToken.promise.then((reason: Cancel) => {
|
cancelToken.promise.then((reason: Cancel) => {
|
||||||
|
const cancelError = new CancelError(reason.message, config);
|
||||||
controller.abort();
|
controller.abort();
|
||||||
reject(reason);
|
reject(cancelError);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,18 +168,17 @@ export const fetchRequest = (config: IrRequestConfig): Promise<IrResponse> => {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch((error: IrError) => {
|
.catch((error: IrError) => {
|
||||||
if (error.name === 'AbortError') {
|
const irError = new IrError(error.message, 'ERR_FETCH_FAILED', responseData.config, responseData.request, responseData);
|
||||||
reject(error.message);
|
reject(irError);
|
||||||
} else {
|
|
||||||
reject(error);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
.catch((error: IrError) => {
|
.catch((error: IrError) => {
|
||||||
if (error.name === 'AbortError') {
|
if (error.name === 'AbortError') {
|
||||||
reject(error.message);
|
const cancelError = new CancelError('request canceled', config);
|
||||||
|
reject(cancelError);
|
||||||
} else {
|
} else {
|
||||||
reject(error);
|
const irError = new IrError(error.message, 'ERR_FETCH_FAILED');
|
||||||
|
reject(irError);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,10 +29,6 @@ export default function processRequest(config: IrRequestConfig): Promise<IrRespo
|
||||||
config.cancelToken.throwIfRequested();
|
config.cancelToken.throwIfRequested();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config.signal && config.signal.aborted) {
|
|
||||||
throw new CancelError(undefined, config);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 拦截可能会传入普通对象
|
// 拦截可能会传入普通对象
|
||||||
config.headers = IrHeaders.from(config.headers as Record<string, any>);
|
config.headers = IrHeaders.from(config.headers as Record<string, any>);
|
||||||
|
|
||||||
|
@ -53,6 +49,16 @@ export default function processRequest(config: IrRequestConfig): Promise<IrRespo
|
||||||
return response;
|
return response;
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch(error => {
|
||||||
|
if (config.signal?.aborted) {
|
||||||
|
error.response = {
|
||||||
|
data: null,
|
||||||
|
headers: config.headers,
|
||||||
|
status: 200,
|
||||||
|
statusText: 'ok',
|
||||||
|
config,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
if (!checkCancel(error)) {
|
if (!checkCancel(error)) {
|
||||||
if (config.cancelToken) {
|
if (config.cancelToken) {
|
||||||
config.cancelToken.throwIfRequested();
|
config.cancelToken.throwIfRequested();
|
||||||
|
|
Loading…
Reference in New Issue