useRequest
useRequest
发起请求的组合式函数
- 旨在解决请求前中后的状态管理、响应数据存储及提供事件钩子
- 可与任意请求库搭配使用
示例
基础示例
ts
import { useRequest } from '@mixte/use';
const {
response,
data,
error,
isExecuted,
isLoading,
isFinished,
isSuccess,
execute,
onSuccess,
onError,
onFinally,
reactive,
} = useRequest(() => {
return axios.get('https://httpbin.org/uuid');
});
在现有项目中使用
修改步骤
- 把现有定义接口的方式, 改为使用
useRequest
的方式:
js
import { useRequest } from '@mixte/use';
function login(info) {
return axios.post('/api/user/login', info);
}
function login() {
return useRequest((info) => {
return axios.post('/api/user/login', info);
});
}
- 在调用端, 从:
js
const form = reactive({ username: '', password: '' });
const data = ref();
const loading = ref(false);
async function submit() {
loading.value = true;
try {
data.value = (await login(form))?.data;
// do something
}
finally {
loading.value = false;
}
}
改为:
js
const form = reactive({ username: '', password: '' });
const { data, isLoading, execute } = login();
async function submit() {
await execute(form);
// do something
}
大功告成 !
同时定义多个请求
INFO
通常, 在页面或组件中都会发起多次请求, 这时候, 可以使用一个变量接受所有的返回值:
ts
// import { getUserInfo, login } from '@/api/auth';
const loginInfo = login();
const userInfo = getUserInfo();
async function submit() {
await loginInfo.execute(/* {...} */);
await userInfo.execute();
console.log(userInfo.data.value.name);
console.log(userInfo.data.value.age);
}
TIP
因为 data
、isLoading
、...
是一个 ref
变量, 所以需要加 .value
取值, 导致调用链很长
往下看, 下面就有解决方案
使用响应式代理式的返回值
INFO
当使用变量接受所有的返回值时, 会导致调用链很长, 这时候, 可以使用响应式代理式的返回值:
ts
// import { getUserInfo, login } from '@/api/auth';
const loginInfo = login().reactive;
const userInfo = getUserInfo().reactive;
async function submit() {
await loginInfo.execute(/* {...} */);
await userInfo.execute();
console.log(userInfo.data.name);
console.log(userInfo.data.age);
}
统一在请求完成后数据处理
ts
// import { getUserInfo, login } from '@/api/auth';
const loginInfo = login().reactive;
const userInfo = getUserInfo().reactive;
userInfo.onSuccess(() => {
userInfo.data.name = 'Mixte';
});
async function submit() {
await loginInfo.execute(/* {...} */);
await userInfo.execute();
console.log(userInfo.data.name); // -> Mixte
}
async function otherLogic() {
await userInfo.execute();
console.log(userInfo.data.name); // -> Mixte
}
配置项
INFO
在定义接口处配置:
ts
function login() {
return useRequest(
info => axios.post('/api/user/login', info),
{ immediate: true }
);
}
const loginInfo = login();
也可以在定义接口处接收相关配置选项, 在调用端根据需求自行配置:
ts
import type { UseRequestOptions } from '@mixte/use';
function login(options?: UseRequestOptions) {
return useRequest(
info => axios.post('/api/user/login', info),
options
);
}
const loginInfo = login({
immediate: true,
resetOnExecute: false,
});
useRequestReactive
发起请求的组合式函数
- 和
useRequest
方法一致, 只是返回响应式代理对象
示例
从 useRequest
改为使用 useRequestReactive
修改步骤
- 原有使用
useRequest
时:
ts
const uuid = useRequest(() => {
return axios.get('https://httpbin.org/uuid');
});
console.log(uuid.response.value); // 需要使用 `.value` 获取值
console.log(uuid.data.value); // 需要使用 `.value` 获取值
console.log(uuid.error.value); // 需要使用 `.value` 获取值
- 修改方法为
useRequestReactive
后:
ts
const uuid = useRequestReactive(() => {
return axios.get('https://httpbin.org/uuid');
});
console.log(uuid.response); // 不用再使用 `.value` 了
console.log(uuid.data); // 不用再使用 `.value` 了
console.log(uuid.error); // 不用再使用 `.value` 了