Skip to content

Latest commit

 

History

History
161 lines (128 loc) · 4.74 KB

README.zh-CN.md

File metadata and controls

161 lines (128 loc) · 4.74 KB

@alova/adapter-xhr

alova 的 XMLHttpRequest 适配器

npm build coverage status typescript license

中文 | 📑English

官网 | 核心库 alova

安装

npm install @alova/adapter-xhr --save

使用方法

创建 alova

使用 xhrRequestAdapter 作为 alova 的请求适配器。

import { createAlova } from 'alova';
import { xhrRequestAdapter } from '@alova/adapter-xhr';

const alovaInst = createAlova(
  // ...
  requestAdapter: xhrResponseAdapter(),
  // ...
);

请求

XMLHttpRequest 适配器提供了基本的配置参数,包含responseTypewithCredentialsmimeTypeauth,具体如下:

const list = () =>
	alovaInst.Get('/list', {
		/**
		 * 设置响应数据类型
		 * 可以设置更改响应类型。 值为:“arraybuffer”、“blob”、“document”、“json”和“text”
		 * 默认为“json”
		 */
		responseType: 'text',

		/**
		 * 当凭证要包含在跨源请求中时为true。 当它们被排除在跨源请求中以及当 cookie 在其响应中被忽略时为 false。 默认为false
		 */
		withCredentials: true,

		/**
		 * 设置响应数据的mimeType
		 */
		mimeType: 'text/plain; charset=x-user-defined',

		/**
		 * auth 表示使用 HTTP Basic 身份验证,并提供凭据。
		 * 这将设置一个 `Authorization` 标头,覆盖任何现有的
		 * 使用 `headers` 设置的 `Authorization` 自定义标头。
		 * 请注意,只有 HTTP Basic 身份验证可以通过此参数进行配置。
		 * 对于 Bearer 令牌等,请改用 `Authorization` 自定义标头。
		 */
		auth: {
			username: 'name1',
			password: '123456'
		}
	});
const { loading, data } = useRequest(list);
// ...

上传

使用FormData上传文件,这个FormData实例会通过xhr.send发送到服务端。

const uploadFile = imageFile => {
	const formData = new FormData();
	formData.append('file', imageFile);
	return alovaInst.Post('/uploadImg', formData, {
		// 开启上传进度
		enableUpload: true
	});
};

const {
	loading,
	data,
	uploading,
	send: sendUpload
} = useRequest(uploadFile, {
	immediate: false
});

// 图片选择事件回调
const handleImageChoose = ({ target }) => {
	sendUpload(target.files[0]);
};

下载

将请求 url 指向文件地址即可下载,你也可以通过将enableDownload设置为 true 来开启下载进度。

const downloadFile = () =>
	alovaInst.Get('/bigImage.jpg', {
		// 开启下载进度
		enableDownload: true,
		responseType: 'blob'
	});

const { loading, data, downloading, send, onSuccess } = useRequest(downloadFile, {
	immediate: false
});
onSuccess(({ data: imageBlob }) => {
	// 下载图片
	const anchor = document.createElement('a');
	anchor.href = URL.createObjectURL(blob);
	anchor.download = 'image.jpg';
	anchor.click();
	URL.revokeObjectURL(anchor.href);
});
const handleImageDownload = () => {
	send();
};

模拟请求适配器兼容

在开发应用时,我们仍然可能需要用到模拟请求。只是默认情况下,模拟请求适配器(@alova/mock)的响应数据是一个Response实例,即默认兼容GlobalFetch请求适配器,当使用 XMLHttpRequest 适配器时,我们需要让模拟请求适配器的响应数据适配 XMLHttpRequest 适配器,此时你需要使用**@alova/adapter-xhr**包中导出的xhrMockResponse作为响应适配器。

import { defineMock, createAlovaMockAdapter } from '@alova/mock';
import { xhrRequestAdapter, xhrMockResponse } from '@alova/adapter-xhr';

const mocks = defineMock({
	// ...
});

// 模拟数据请求适配器
export default createAlovaMockAdapter([mocks], {
	// 指定请求适配器后,未匹配模拟接口的请求将使用这个适配器发送请求
	httpAdapter: xhrRequestAdapter(),

	// 使用xhrMockResponse,让模拟数据适配XMLHttpRequest适配器
	onMockResponse: xhrMockResponse
});

export const alovaInst = createAlova({
	// ...
	// 通过环境变量控制是否使用模拟请求适配器
	requestAdapter: process.env.NODE_ENV === 'development' ? mockAdapter : xhrRequestAdapter()
});