我想添加变量到我的swr,其中获取使用graphql请求。这是我的代码
import { request } from "graphql-request";
import useSWR from "swr";
const fetcher = (query, variables) => request(`https://graphql-pokemon.now.sh`, query, variables);
export default function Example() {
const variables = { code: 14 };
const { data, error } = useSWR(
`query GET_DATA($code: String!) {
getRegionsByCode(code: $code) {
code
name
}
}`,
fetcher
);
if (error) return <div>failed to load</div>;
if (!data) return <div>loading...</div>;
return <pre>{JSON.stringify(data, null, 2)}</pre>;
}
但是我不知道如何将variables
添加到swr fetcher中,因为我知道useSWR(String, fetcher)
字符串用于查询,而fetcher用于获取函数,我可以在哪里放置变量?
4条答案
按热度按时间ghhkc1vu1#
你可以使用多个参数,你可以使用一个数组作为
useSWR
react钩子的key
参数。函数
fetcher
仍然接受相同的两个参数:query
和variables
。zsohkypk2#
作者在这里!
同意这是一个关键的功能,这就是为什么从v1.1.0开始,SWR密钥将自动稳定地序列化。你可以安全地做到这一点:
虽然
variables
可以是一个JavaScript对象(可以嵌套,也可以是一个数组),但它不会导致任何不必要的重新呈现。此外,序列化过程是稳定的,因此以下键是相同的,没有额外的请求:你也可以直接传递一个对象作为key,它会被传递给fetcher:
你可以通过安装最新版本的SWR来尝试一下,如果有任何问题请告诉我:)
eivnm1vs3#
slideshowp2的解决方案对我没有帮助,因为它导致了一个无限循环。
不要将对象传递给
useSWR
函数,因为它们在每次重新渲染时都会改变。直接传递变量:xfb7svmp4#
我花了一段时间试图在这篇文章中实现“最佳答案”解决方案,但它根本不起作用。经过大量的调试和遵循swr's docs提供的指南,我终于得到了以下解决方案:
(note我决定使用一个元组,但你可以做任何事情)