我正在做一个React JS项目。我正在使用React Hooks(功能组件)和React query。
我通常在功能组件中按以下方式运行/执行查询。
const ItemList = (props) => {
let getItemsQuery = useQuery([ 'get-items' ], getItems, {
retry: false,
refetchOnWindowFocus: false
});
// The rest of the code goes here
}
基本上,查询是在加载组件时执行的,因此也会进行API调用。
现在,我正在寻找一种方法,仅在单击按钮时才可以执行查询。
return (
<button onClick={() => {
//make the call. The value or value might be overridden when the API call is made when the Call 2 button is clicked
}}>Call 1</button>
<button onClick={() => {
//make the call. The value or value might be overridden when the API call is made when the Call 1 button is clicked
}}>Call 2</button>
)
正如您在上面的虚拟代码中看到的那样,该注释解释了我想要实现的目标。我该怎么办?
答案 0 :(得分:1)
从this answer中拉出:
import React, { useState } from "react";
import { useQuery } from "react-query";
const App = (props) => {
const [text, setText] = useState("");
// use your async request (axios, fetch, etc)
// useQuery expects a Promise so we can safely use this instead
const emulateFetch = async (_) => {
// axios.get (...)
console.log(`Passing ${text} to fetch`);
return new Promise((resolve) => {
resolve([{ data: "ok" }]);
});
};
const handleClick = () => {
// manually refetch
refetch();
};
const { isLoading, error, data, refetch } = useQuery(
["key", { text }],
emulateFetch,
{
refetchOnWindowFocus: false,
enabled: false // needed to handle refetchs manually
}
);
if (isLoading) return <div>Loading...</div>;
if (error) return <div>Error: {error}</div>;
return (
<div>
<p>Home page</p>
<input
type="text"
value={text}
onChange={(event) => setText(event.target.value)}
/>
<button onClick={handleClick}>Click me</button>
{JSON.stringify(data)}
</div>
);
};
export default App;
工作sandbox。