只是想知道将letterSelected传递到useLazyQuery fetchMovies查询的最佳方式,这样我就不必使用静态变量"A";。我希望有一种方法可以将它直接传递到fetchMovies中。useLazyQuery是一个apollo查询。
const BrowseMovies = () => {
const [fetchMovies, { data, loading}] = useLazyQuery(BROWSE_MOVIES_BY_LETTER, {
variables: {
firstLetter: "A"
}
})
return (
<div className="browserWrapper">
<h2>Browse Movies</h2>
<AlphabetSelect
pushLetterToParent={fetchMovies}
/>
{
data && !loading &&
data.browseMovies.map((movie: any) => {
return (
<div className="browseRow">
<a className="movieTitle">
{movie.name}
</a>
</div>
)
})
}
</div>
)
}
export default BrowseMovies
const AlphabetSelect = ({pushLetterToParent}: any) => {
const letters = ['A','B','C','D','E','F','G','H','I','J','K','L', 'M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','#']
const [selectedLetter, setSelectedLetter] = useState("A")
const onLetterSelect = (letter: string) => {
setSelectedLetter(letter.toUpperCase())
pushLetterToParent(letter.toUpperCase())
}
return (
<div className="alphabetSelect">
{
letters.map((letter: string) => {
return(
<div
className={selectedLetter === letter ? 'letterSelectActive' : 'letterSelect'}
onClick={() => onLetterSelect(letter)}
>
{letter}
</div>
)
})
}
</div>
)
}
export default AlphabetSelect
这似乎是通过提升状态来解决的问题。useLazyQuery
接受gql查询和选项,并返回一个函数以在以后执行查询。听起来您希望子组件更新variables
配置参数。
浏览电影
-
移动
firstLetter
状态BrowseMovies
组件 -
从状态更新查询参数/选项/配置
-
添加
useEffect
以在状态更新时触发提取 -
将
firstLetter
状态和setFirstLetter
状态更新器传递给子组件const BrowseMovies = () => { const [firstLetter, setFirstLetter] = useState(''); const [fetchMovies, { data, loading}] = useLazyQuery( BROWSE_MOVIES_BY_LETTER, { variables: { firstLetter } } // <-- pass firstLetter state ); useEffect(() => { if (firstLetter) { fetchMovies(); // <-- invoke fetch on state update } }, [firstLetter]); return ( <div className="browserWrapper"> <h2>Browse Movies</h2> <AlphabetSelect pushLetterToParent={setFirstLetter} // <-- pass state updater selectedLetter={firstLetter} // <-- pass state /> { data && !loading && data.browseMovies.map((movie: any, index: number) => { return ( <div key={index} className="browseRow"> <a className="movieTitle"> {movie.name} </a> </div> ) }) } </div> ) }
字母选择
-
将
pushLetterToParent
回调附加到div
的onClick
处理程序const AlphabetSelect = ({ pushLetterToParent, selectedLetter }: any) => { const letters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ#'; return ( <div className="alphabetSelect"> { letters.split('').map((letter: string) => { return( <div key={letter} className={selectedLetter === letter ? 'letterSelectActive' : 'letterSelect'} onClick={() => pushLetterToParent(letter.toUpperCase())} > {letter} </div> ) }) } </div> ) }