我正在使用useEffect和useState react钩子在select更改事件上设置GraphQL变量,并根据第一个下拉菜单的选项用数据填充第二个select
所以当我选择选项A时,gql变量应该更新如下:
{
variables: {
selectedOption: "A"
}
}
但不知何故,useEffect()上没有设置selectOption。在useEffect之外,selectOption受setSelectOption的影响。
我做错了什么?
我的GraphQL查询:
import {gql} from "@apollo/client";
export const GET_SELECT = gql`
query getSelect($selectedOption: String!) {
categories(where: {name: $selectedOption}) {
edges {
node {
children {
edges {
node {
name
}
}
}
}
}
}
}
`;
我的React组件
import React, {useState, useEffect} from 'react';
import {useQuery} from "@apollo/client";
import {GET_SELECT} from "./app/queries/get-select";
const FilterBar = ({options}) => {
const [ selectOption, setSelectOption] = useState('');
const { data, loading, error } = useQuery(GET_SELECT, {
variables: {
selectedOption: selectOption
}
});
useEffect(() => {
setSelectOption(data?.categories?.edges?.map(first => first?.node?.children?.edges?.map(second => second?.node?.name)));
console.log('select option' + selectOption);
}, [data, setSelectOption]);
if (loading) return "Loading...";
if (error) return <pre>{( error?.message )}</pre>
return (
<>
<select onChange={(e) => setSelectOption(e.target.value)}>
<option value="">Select option</option>
<option value="A">Option A</option>
<option value="B">Option B</option>
<option value="C">Option C</option>
</select>
<br/>
<select>
<option value="">Select data</option>
{data &&
data?.map(opt =>
<option value={opt} key={opt}>{opt}</option>
)
}
</select>
</>
)
}
export default FilterBar;
请注意,setSelectOption
不会立即更新值。因此,如果您想查看该行之后的更改,请尝试添加selectOption
作为依赖项,或者创建仅包含selectOption
的新useEffect
块
useEffect(() => {
setSelectOption(data?.categories?.edges?.map(first => first?.node?.children?.edges?.map(second => second?.node?.name)));
console.log('select option' + selectOption);
}, [data, setSelectOption, selectOption]);
或
useEffect(() => {
console.log('select option' + selectOption);
}, [selectOption])
对于Graphql查询,请尝试以下代码。
export const GET_SELECT = gql`
query ($selectedOption: String!) {
getSelect() {
categories(where: { name: $selectedOption }) {
edges {
node {
children {
edges {
node {
name
}
}
}
}
}
}
}
}
`;
ok我发现Graphql变量'name'正在返回一个数组,所以我不得不像这样更改查询:
const GET_SELECT = gql`
query getSelect($selectedOption: [String!]) {
categories(where: {name: $selectedOption}) {
edges {
node {
children {
edges {
node {
name
}
}
}
}
}
}
}
`;
在反应组分中:
const { data, loading, error } = useQuery(GET_SELECT, {
variables: { name: [selectOption] },
});
现在一切正常无论如何感谢@endmaster0809的帮助!