Skip to main content
Version: v3

Uniapp Adapter

Tips

This plugin only supports vue3 version of uniapp application.

Install

npm install alova @alova/adapter-uniapp @alova/shared --save

Usage

create alova

Calling AdapterUniapp will return Request Adapter, Storage Adapter, and VueHook, so you no longer need to set these three items, and the usage is exactly the same.

import { createAlova } from 'alova';
import AdapterUniapp from '@alova/adapter-uniapp';

const alovaInst = createAlova({
baseURL: 'https://api.alovajs.org',
...AdapterUniapp()
});

Request

The usage method of the request is exactly the same as that used in the web environment. Already fully compatible with uni.request, you can specify [all configuration items] supported by uni.request in config of method instance creation (https://uniapp.dcloud.net.cn/api/request/ request.html)

<template>
<view v-if="loading">Loading...</view>
<view>The requested data is: {{ data }}</view>
</template>

<script setup>
const list = () =>
alovaInst.Get('/list', {
// The set parameters will be passed to uni.request
enableHttp2: true,
sslVerify: true
});
const { loading, data } = useRequest(list);
</script>

When using useRequest/useWatcher to send a request immediately, it will be executed asynchronously in the onLoad hook, so you can access the options data in methodHandler as follows:

import { onLoad } from '@dcloudio/uni-app';

let options = {};
onLoad(opt => {
options = opt;
});
const { loading, data } = useRequest(() => getDetail(options.id));

Upload

When requestType: 'upload' is set in the config of the method instance, it means to upload the file, the request adapter will call uni.uploadFile, and the uploaded file data is placed in the data of the method instance, you need to specify in the data name, filePath or files, and file (if necessary), these 4 parameters will be passed to uni.uploadFile, at the same time, you can also specify other parameters besides these 4 parameters in data , the request adapter will pass them into the formData parameter.

Similarly, it is fully compatible with uni.uploadFile, you can specify [all configuration items] supported by uni.uploadFile in config of method instance creation (https://uniapp.dcloud.net.cn/api /request/network-file.html#uploadfile), if there are additional parameters to be set, please specify them in config of the method instance.

<template>
<view v-if="loading">Uploading...</view>
<view>Upload progress: {{ uploading.loaded }}/{{ uploading.total }}</view>
<button @click="handleImageChoose">Upload image</button>
<!-- ... -->
</template>

<script setup>
const uploadFile = (name, filePath, formData) =>
alovaInst.Post(
'/uploadImg',
{
name,
filePath,

// Additional data will be passed into formData of uni.uploadFile
...formData
},
{
// Set the request method to upload, and the adapter will call uni.uploadFile
requestType: 'upload',
fileType: 'image'
}
);

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

const handleImageChoose = () => {
uni.chooseImage({
success: chooseImageRes => {
const tempFilePaths = chooseImageRes.tempFilePaths;
send('fileName', tempFilePaths[0], {
extra1: 'a',
extra2: 'b'
});
}
});
};
</script>

download

When requestType: 'download' is set in the config of the method instance, it means to download the file, and the request adapter will call uni.downloadFile.

Similarly, it is fully compatible with uni.downloadFile, you can specify [all configuration items] supported by uni.downloadFile in config of method instance creation (https://uniapp.dcloud.net.cn/api /request/network-file.html#downloadfile), if there are additional parameters to be set, please specify them in config of the method instance.

<template>
<view v-if="loading">Downloading...</view>
<view>Download progress: {{ downloading.loaded }}/{{ downloading.total }}</view>
<button @click="handleImageDownload">Download image</button>
<!-- ... -->
</template>

<script setup>
const downloadFile = filePath =>
alovaInst.Get('/bigImage.jpg', {
// Set the request method to download, and the adapter will call uni.downloadFile
requestType: 'download',
filePath
});

const { loading, data, downloading, send } = useRequest(downloadFile, {
immediate: false
});

const handleImageDownload = () => {
send('file_save_path');
};
</script>

Mock request adapter compatible

When using uniapp to develop applications, we may still need to use simulated requests, but by default, the response data of mock adapter (@alova/mock) is a Response instance, That is, it is compatible with the alova/fetch request adapter by default. When used in the uniapp environment, we need to make the response data of the simulated request adapter compatible with the uniapp adapter, so you need to use the @alova/adapter-uniapp package exported uniappMockResponse as response adapter.

import { defineMock, createAlovaMockAdapter } from '@alova/mock';
import AdapterUniapp, { uniappRequestAdapter, uniappMockResponse } from '@alova/adapter-uniapp';

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

// mock data request adapter
export default createAlovaMockAdapter([mocks], {
// After specifying the uniapp request adapter, requests that do not match the simulated interface will use this adapter to send requests
httpAdapter: uniappRequestAdapter,

// Simulate the response adapter, after specifying, the response data will be converted to a uniapp-compatible data format
onMockResponse: uniappMockResponse
});

export const alovaInst = createAlova({
baseURL: 'https://api.alovajs.org',
timeout: 5000,
...AdapterUniapp({
// Control whether to use the simulated request adapter through environment variables
mockRequest: process.env.NODE_ENV === 'development' ? mockAdapter : undefined
})
//...
});

Typescript

uniapp request adapter provides complete type adaptation, and the type of method configuration and response data will exactly match the type of uniapp.

method configuration

When creating a method instance, in addition to the general configuration items in the method, you can also use the configuration items in uniapp.request, uniapp.uploadFile and uniapp.downloadFile, we have removed and method from the type Items that conflict with the common configuration of the instance.

/**
* uni.request requests additional parameters
*/
export type UniappRequestConfig = Omit<
UniNamespace.RequestOptions,
'url' | 'data' | 'header' | 'method' | 'timeout' | 'success' | 'fail' | 'complete'
>;

/**
* uni.uploadFile additional parameters
*/
export type UniappUploadConfig = Omit<
UniNamespace.UploadFileOption,
'url' | 'name' | 'header' | 'formData' | 'timeout' | 'success' | 'fail' | 'complete'
>;

/**
* uni.downloadFile additional parameters
*/
export type UniappDownloadConfig = Omit<
UniNamespace.DownloadFileOption,
'url' | 'header' | 'timeout' | 'success' | 'fail' | 'complete'
>;

/**
* Merged request configuration parameters
*/
export type UniappConfig = {
/**
* Request type, upload means upload, download means download, not filling means normal request
*/
requestType?: 'upload' | 'download';
} & UniappRequestConfig &
UniappUploadConfig &
UniappDownloadConfig;

Response data

Because the uniapp request adapter is compatible with uniapp.request, uniapp.uploadFile and uniapp.downloadFile, but their response value types are slightly different, so the response data type is as follows:

type UniappResponse =
// The response type of uni.request
| UniNamespace.RequestSuccessCallbackResult

// The response type of uni.uploadFile
| UniNamespace.UploadFileSuccessCallbackResult

// The response type of uni.downloadFile
| UniNamespace.DownloadSuccessData;

In actual use, we usually need to process the response data globally. It is recommended to judge the returned data separately. A simple example is as follows:

const alovaInst = createAlova({
baseURL: 'https://api.alovajs.org',
...AdapterUniapp(),
responded(response) {
const { statusCode, data } = response as UniNamespace.RequestSuccessCallbackResult;
if (statusCode >= 400) {
throw new Error('request error');
}
return data || null;
}
});