@sinoui/use-data-api
使用 React Hooks 实现数据加载的库。
安装
yarn add @sinoui/use-data-api
或者
npm i --save @sinoui/use-data-api
使用
简单示例:
import React, { useState } from 'react';
import useDataApi from '@sinoui/use-data-api';
interface User {
userId: string;
userName: string;
}
function UserList() {
const { data, isLoading, isError, doFetch } = useDataApi<User[]>(
'/users',
[],
);
return (
<div>
{isLoading && <div>正在加载数据</div>}
{isError && <div>加载数据失败</div>}
<ul>
{data.map((user) => (
<li key={user.id}>{user.userName}</li>
))}
</ul>
</div>
);
}
查询示例:
import React, { useState } from 'react';
import useDataApi from '@sinoui/use-data-api';
interface User {
userId: string;
userName: string;
}
function UserList() {
const [searchText, setSearchText] = useState('');
const { data, isLoading, isError, doFetch } = useDataApi<User[]>(
'/users',
[],
);
const handleSearch = () => {
doFetch(`/users?text=${searchText}`);
setSearchText('');
};
return (
<div>
<form>
<label>姓名</label>
<input
type="text"
value={searchText}
onChange={(event) => setSearchText(event.target.value)}
/>
<button onClick={handleSearch}>查询</button>
</form>
{isLoading && <div>正在加载数据</div>}
{isError && <div>加载数据失败</div>}
<ul>
{data.map((user) => (
<li key={user.id}>{user.userName}</li>
))}
</ul>
</div>
);
}
另外一个加载 Hacker News 的例子:
方法说明
import useDataApi from '@sinoui/use-data-api';
interface DataSource<T> {
/**
* 从API中获取到的数据
*/
data: T;
/**
* 数据加载中状态。`true`表示数据加载中。
*/
isLoading: boolean;
/**
* 数据加载失败状态。`true`表示数据加载失败。
*/
isError: boolean;
/**
* 加载数据
*
* @param {string} url 获取数据的url
* @param {boolean} forceFetch 当指定的`url`与上一次请求的`url`一致时,是否发送API请求。
* 默认为`true`,表示发送请求。
*/
doFetch: (url?: string, forceFetch?: boolean) => void;
/**
* 重新加载数据
*/
reload: () => void;
/**
* 更新数据
*/
setData: (data: T) => void;
}
/**
* 数据加载hook
*
* @template T
* @param {string} defaultUrl 默认加载数据的链接
* @param {T} defaultValue 默认数据
* @param {HttpRequestConfig} httpRequestConfig 请求配置
* @returns {DataSource<T>}
*/
function useDataApi<T>(
defaultUrl: string | undefined,
defaultValue: T,
httpRequestConfig: HttpRequestConfig,
): DataSource<T>;
默认通过GET
方法发送 API 请求,获取到的响应数据直接作为dataSource.data
。可以通过httpRequestConfig
来调整,如下所示:
const transformResponse = (data) => data.map((item) => item.userName); // 将人员信息列表转换成人名列表
const dataSource = useDataApi('/users', [], {
transformResponse,
method: 'POST',
});
更多请求配置参见Axios Request Config。
注意:如果url
为空(''
、null
、undefined
)时,则不会发送 API 请求。