【问题标题】:Apollo GraphQL query inside of react custom hookReact 自定义钩子中的 Apollo GraphQL 查询
【发布时间】:2021-06-14 03:15:47
【问题描述】:

我正在尝试列出 Rick & Morty API 中的所有角色。我编写了以下钩子以在要呈现结果的组件中使用。当我硬编码值时,例如:(page: 1 , filter: { name : "Rick"}) 查询运行得很好。如果我尝试使用变量,它会返回错误 400 错误请求(我假设这意味着我的 $page / $filter 值无效,我试图检查它们中的值 + 它们的类型一切似乎都很好)我查看了Apollo | Queries - Client (React) 的文档,并确保我使用正确的语法将变量注入到查询中。该查询来自官方 Rick & Morty API 文档API Docs。非常感谢任何指导/方向。

使用CharecterList 挂钩 参数:页面:编号 |过滤器:字符串

import { useQuery, gql } from '@apollo/client';

const CHARECTERS_LIST = gql`
query ($page: Number!, $filter: String!){
  characters
    (page: $page , filter: { name : $filter}) {
        info {
          next
          prev
        }
        results {
          id
          name
          image
        }
      }
  }
`;

export default function useCharecterList({page, filter}){  
    return useQuery(CHARECTERS_LIST, {
      variables: {page, filter}
    });
}

组件渲染结果:

import useCharecterList from '../hooks/useCharecterList'
import { Fragment } from 'react';
import InputComponent from './InputComponent';


function CharectersList() {
  const { loading, error, data } = useCharecterList({page: 1, filter: "Rick"});
  if (loading) return <p>Loading...</p>;
  if (error) return <p>Error :(</p>;
  const options = data.characters.results.map(({name}) =>{
      return name;
  })
  return(
    <Fragment>
      <InputComponent options={options}></InputComponent>
      {
           data.characters.results.map(({ id, name, image }) => (
            <div key={id}>
                <img src={image} alt={`${name} from the popular sitcom Rick & Morty`}/>
                <p>{name}</p>
            </div>
          ))
      }
    </Fragment>
  )


}

export default CharectersList

【问题讨论】:

  • 使用“查询变量”选项在操场上测试...检查网络请求和响应详细信息
  • useCharecterList(vars){ return useQuery(CHARECTERS_LIST, { variables: vars ?
  • ...但是以前的也应该可以工作...错误的变量 ($filter) 类型 - 它必须符合 BE/API 规范...一如既往,未在操场上测试;)跨度>

标签: reactjs graphql react-hooks apollo apollo-client


【解决方案1】:

我想通了...就像一个白痴一样,我假设查询类型只是您的普通 JS 类型。经过一番挖掘,我得到它的工作如下。

import { useQuery, gql } from '@apollo/client';

const CHARECTERS_LIST = gql`
query CharectersList($page: Int!, $filter: FilterCharacter!){
  characters
    (page: $page, filter: $filter) {
        info {
          next
          prev
        }
        results {
          id
          name
          image
        }
      }
  }
`;

export default function useCharecterList(options){  
    return useQuery(CHARECTERS_LIST, options);
}

import useCharecterList from '../hooks/useCharecterList'
import { Fragment } from 'react';
import InputComponent from './InputComponent';


function CharectersList() {
  const { loading, error, data } = useCharecterList({variables: {page: 1, filter: { name: "Summer" }}});
  if (loading) return <p>Loading...</p>;
  if (error) {
    console.log(error);
    return <p>Error :(</p>}
  const options = data.characters.results.map(({name}) =>{
      return name;
  })
  return(
    <Fragment>
      <InputComponent options={options}></InputComponent>
      {
           data.characters.results.map(({ id, name, image }) => (
            <div key={id}>
                <img src={image} alt={`${name} from the popular sitcom Rick & Morty`}/>
                <p>{name}</p>
            </div>
          ))
      }
    </Fragment>
  )


}

export default CharectersList

【讨论】:

  • 无用的钩子/构造......从单独的.graphql文件加载/导入查询并使用普通useQuery就足够了
猜你喜欢
  • 2020-12-14
  • 1970-01-01
  • 2019-12-20
  • 2021-08-18
  • 2018-05-04
  • 2020-11-11
  • 2020-07-04
  • 1970-01-01
  • 2020-11-04
相关资源
最近更新 更多