【发布时间】:2020-03-23 18:26:44
【问题描述】:
import * as React from "react";
import axios from "axios";
import {Fragment, useState, useEffect} from "react";
interface Ihits {
objectID: string;
url: string;
title: string;
}
interface IinitialData<T> {
hits: Array<T>
}
const useDataApi = (initialUrl:string, initialData: IinitialData<Ihits>) => {
const [data, setData] = useState(initialData);
const [url, setUrl] = useState(initialUrl);
const [isLoading, setIsLoading] = useState(false);
const [isError, setIsError] = useState(false);
useEffect(() => {
const fetchData = async () => {
setIsError(false);
setIsLoading(true);
try {
const result = await axios(url);
setData(result.data);
} catch (error) {
setIsError(true);
}
setIsLoading(false);
};
fetchData();
}, [url]);
// return [{ data, isLoading, isError }, setUrl];
return [{data, isLoading, isError }, setUrl];
};
const UseDataFetch: React.FC = () => {
const [query, setQuery] = useState('redux');
**const [{data, isLoading, isError}, setUrl] = useDataApi(**
'https://hn.algolia.com/api/v1/search?query=redux',
{ hits: [] },
);
return (
<Fragment>
<form
onSubmit={event => {
**setUrl(**
`http://hn.algolia.com/api/v1/search?query=${query}`,
);
event.preventDefault();
}}
>
<input
type="text"
value={query}
onChange={event => setQuery(event.target.value)}
/>
<button type="submit">Search</button>
</form>
{isError && <div>Something went wrong ...</div>}
{isLoading ? (
<div>Loading ...</div>
) : (
<ul>
{data.hits.map((item: Ihits) => (
<li key={item.objectID}>
<a href={item.url}>{item.title}</a>
</li>
))}
</ul>
)}
</Fragment>
);
}
export default UseDataFetch;
我研究了这个链接https://www.robinwieruch.de/react-hooks-fetch-data的例子
我尝试了各种解决方案,但根本无法设置类型化解构值。除了使用任何类型和对象返回(例如:return {data, isLoading, isError, setUrl};)
很感激有人能告诉我错过了什么
【问题讨论】:
-
TS 是否抛出错误?
-
@azium 在文本编辑器中抛出 ts 错误
标签: javascript reactjs typescript type-inference destructuring