gpt4 book ai didi

javascript - Apollo React 为什么不能在 UseEffect 钩子(Hook)中查询

转载 作者:行者123 更新时间:2023-12-04 14:55:45 25 4
gpt4 key购买 nike

我只是在学习 Apollo-React,但我无法提出 graphql 请求
这就是我没有 Apollo 的方式

const Search = () => {
const [searchedText, setSearchedText] = React.useState('')
const [suggestions, setSuggestions] = React.useState([])
const [selected, setSelected] = React.useState(null)

const debounceHandler = (searchedText) => debounce(() => {
sendQuery(`{search(str:"${searchedText}") {name}}`).then(({search}) => {
if (!search) return
setSuggestions(search)
})
}, 500)

const handleInputChange = async (e) => {
if(e.key === 'Enter') {
const name = e.target.value
sendQuery(`{getPokemon(str:"${name}"){name, image}}`).then(({getPokemon}) => {
setSelected(getPokemon)
})
}
debounceHandler(searchedText)()
}

return (
<div>
<h1>Pokemon Search</h1>
<input type="text" value={searchedText} onChange={(e) => setSearchedText(e.target.value)} onKeyUp={(e) => handleInputChange(e)} style={{width:'100%'}} />
<hr />
<div>
{selected ? <PokemonProfile selected={selected} /> : suggestions.map(({name}) => (
<ShowSuggestion name={name} searchedText={searchedText} setSelected={setSelected}/>
)) }
</div>
</div>
)
}

现在没有我自己的 sendQuery 函数,我想使用 Apollo 的 useQuery 钩子(Hook)。
const GET_POKEMON = gql`
query getPokemon ($str: String!) {
getPokemon(str: $str) {
name
image
}
}
`;

const SEARCH = gql `
query search($str: String!) {
search(str:$str) {
name
}
}
`;

这些是我在操场上正确的查询和结果。现在我再次编写搜索功能。我说每当 searchedText 发生变化(当用户输入时),查询 Search 并将返回的数据设置为建议。每当用户按 Enter 键时,我想从后端查询 Pokemon 并将其设置为选中状态。

const Search = () => {
const [searchedText, setSearchedText] = React.useState(null)
const [suggestions, setSuggestions] = React.useState([])
const [selected, setSelected] = React.useState(null)

React.useEffect(() => {
const { data } = useQuery(SEARCH, {
variables: { "str": searchedText },
pollInterval: 500,
});

if (data) {
setSuggestions(data)
}

}, [searchedText])


const fetchAndSelect = name => {
setSearchedText('')
const { pokemon } = useQuery(GET_POKEMON, {
variables: {
"str": name
}
})

setSelected(pokemon)
}



const handleInputChange = (e) => {
const name = e.target.value
if(e.key === 'Enter') {
return fetchAndSelect(name)
}
setSearchedText(name)
}


return (
<div>
<h1>Pokemon Search</h1>
<input type="text" value={searchedText} onKeyUp={(e) => handleInputChange(e)} style={{width:'100%'}} />
<hr />
<div>
{selected ? <PokemonProfile selected={selected} /> : suggestions.map(({name}) => (
<ShowSuggestion name={name} searchedText={searchedText} setSelected={setSelected}/>
))}
</div>
</div>
)
}

但这给出了 Invalid hook调用错误。如果我不在 useEffect 中进行查询(我不确定这有什么问题?)这次我得到 Rendered more hooks than during the previous render.错误。我不确定我做错了什么?
编辑
根据答案,我编辑如下代码
const Search = () => {
const [searchedText, setSearchedText] = React.useState(null)
const [suggestions, setSuggestions] = React.useState([])
const [selected, setSelected] = React.useState(null)
const debouncedSearch = debounce(searchedText, 1000) // Trying to debounce the searched text
const [searchPokemons, { data }] = useLazyQuery(SEARCH);
const [getPokemon, { pokemon }] = useLazyQuery(GET_POKEMON)

React.useEffect(() => {
if (!searchedText) return

setSelected(null)
searchPokemons({ variables: { str: searchedText }})

if (data) {
console.log(data)
setSuggestions(data)
}

}, [debouncedSearch])


const fetchAndSelect = name => {
setSearchedText('')
getPokemon({variables: {str: name}})
if (pokemon) {
setSelected(pokemon)
}
}

const handleInputChange = (e) => {
const name = e.target.value
if(e.key === 'Enter') {
return fetchAndSelect(name)
}
setSearchedText(name)
}

return (
<div>
<h1>Pokemon Search</h1>
<input type="text" value={searchedText} onKeyUp={(e) => handleInputChange(e)} style={{width:'100%'}} />
<hr />
<div>
{selected ? <PokemonProfile selected={selected} /> : suggestions.map(({name}) => (
<ShowSuggestion name={name} searchedText={searchedText} setSelected={setSelected}/>
))}
</div>
</div>
)
}
我无法在输入中输入任何内容。它像疯了似的。请帮忙

最佳答案

您应该使用 使用惰性查询 在这种情况下 Hook 。它对于发生在未知时间点的事情非常有用,例如响应用户的搜索操作。
如果你在函数顶部调用 use 你的钩子(Hook),然后在 useEffect 钩子(Hook)中调用它。

const [search, { data }] = useLazyQuery(SEARCH, {
variables: { "str": searchedText },
pollInterval: 500,
});

React.useEffect(() => {
if (searchedText)
search() // Function for executing the query

if (data)
setSuggestions(data)

}, [searchedText])

如您所见,useLazyQuery 以同步方式处理获取数据,没有任何 promise 。

关于javascript - Apollo React 为什么不能在 UseEffect 钩子(Hook)中查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68055994/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com