【发布时间】:2020-06-03 10:34:11
【问题描述】:
我正在尝试创建一个 API 服务来获取我所有组件中的数据。 我被 Typescript 困住了(我不太擅长)
我创建了一个自定义钩子:
使用ApiService.tsx
import React from 'react'
import axios from 'axios'
const useApiService = (url: string) => {
const baseUrl = 'http://localhost:8009'
const [response, setResponse] = React.useState(null)
const [error, setError] = React.useState(null)
React.useEffect(() => {
const fetchData = async (): Promise<void> => {
try {
const res = await axios(`${baseUrl}${url}`)
setResponse(res.data)
} catch (error) {
setError(error)
}
}
fetchData()
}, [url])
return { response, error }
}
export default useApiService
然后像这样在我的组件中使用这个钩子:
Header.tsx
import React from 'react'
import { Button, Form, FormControl, Navbar, NavItem } from 'react-bootstrap'
import Nav from 'react-bootstrap/Nav'
import { Link } from '@reach/router'
import useApiService from '../services/useApiService'
interface NavigationData {
title: string
ID: string
post_excerpt: string
}
interface SiteData {
name: string
}
const Header: React.FC = () => {
const menuQuery: Array<NavigationData> = useApiService('/wp-json/wp-utils/menus')
const siteNameQuery: SiteData = useApiService('/wp-json')
const data = menuQuery.response
const siteName = siteNameQuery.response
if (data && siteName)
return (
<Navbar bg="primary" expand="lg" className="navbar-dark mb-4">
<Link to={'/'}>
<Navbar.Brand>{siteName.name}</Navbar.Brand>
</Link>
<Navbar.Toggle aria-controls="basic-navbar-nav" />
<Navbar.Collapse id="basic-navbar-nav">
<Nav className="mr-auto">
{data.map((item: NavigationData) => (
<NavItem key={item.ID}>
<Link className="nav-link" to={item.post_excerpt}>
{item.title}
</Link>
</NavItem>
))}
</Nav>
<Form className={'my-2 my-lg-0'} inline>
<FormControl type="text" placeholder="Recherche" className="mr-sm-2" />
<Button variant="light" className="my-2 my-sm-0">
Search
</Button>
</Form>
</Navbar.Collapse>
</Navbar>
)
else return null
}
export default Header
但我有打字错误Type '{ response: null; error: null; }' is missing the following properties from type 'NavigationData[]': length, pop, push, concat, and 28 more.
我想将数据接口或类型从我的组件注入到我的自定义挂钩中,但我不知道这是否是执行此操作的好方法,以及如何正确执行此操作。
感谢您的建议
【问题讨论】:
-
useApiService返回{ response, error },但您将其分配给const menuQuery: Array<NavigationData>。这就是你出错的原因。你想让useApiService中的response具有Array<NavigationData>类型吗?
标签: reactjs typescript react-hooks typescript-typings