我正在尝试在我的功能组件中使用 fetching helper 函数,但 React 抱怨:
src\components\Header.js
第 19:30 行:在函数“handleSearch”中调用 React Hook“useFetch”,该函数既不是 React 函数组件,也不是自定义 React Hook 函数。React 组件名称必须以大写字母开头 react-hooks/rules-of-hooks
我知道功能组件应该以大写字母开头,但是 useFetch 不是组件,它只是一个辅助函数。我究竟做错了什么?我知道我可以通过调用我的函数 UseEffect 而不是 useEffect 来解决这个问题,但我应该这样做吗?
这是我的 helper.js
import { useState, useEffect } from 'react';
export const GH_BASE_URL = 'https://api.github.com/';
export const useFetch = (url, options) => {
const [response, setResponse] = useState(null);
const [error, setError] = useState(null);
const [isLoading, setIsLoading] = useState(false);
useEffect(() => {
const fetchData = async () => {
setIsLoading(true);
try {
const res = await fetch(url, options);
const json = await res.json();
setResponse(json);
setIsLoading(false);
} catch (error) {
setError(error);
}
};
if(url) {
fetchData();
}
}, []);
return { response, error, isLoading };
};
和我的 Header.js 组件
import React, { useState } from 'react';
import { useFetch, GH_BASE_URL } from '../helpers';
const REPO_SEARCH_URL = `${GH_BASE_URL}/search/repositories?q=`;
function Header(props) {
const [searchValue, setSearchValue] = useState('');
function handleChange(event) {
setSearchValue(event.target.value);
}
async function handleSearch(event) {
event.preventDefault();
const response = useFetch(`${REPO_SEARCH_URL}${searchValue}`);
}
return (
<header>
<form
onSubmit={handleSearch}
className="container"
>
<input
value={searchValue}
onChange={handleChange}
className="search-input"
placeholder="Search a repository">
</input>
</form>
</header>
);
}
export default Header;