将 ApolloError 传播到客户端

我真的很难在客户端获得自定义 Apollo 错误。


这是服务器代码:


...

const schema = makeExecutableSchema({

  typeDefs: [constraintDirectiveTypeDefs, ...typeDefs],

  resolvers,

  schemaTransforms: [constraintDirective()],

});



const server = new ApolloServer({

  schema,

  dataSources,

  context({ req }) {

    const token = req.headers.authorization;


    const user = token ? getUserFromToken(token) : '';


    return { user };

  },


  debug: false,

  formatError: (err) => { 

    // ToDo: Generate unique token and log error

    if (err!.extensions!.code == 'INTERNAL_SERVER_ERROR') {

      return new ApolloError('We are having some trouble', 'ERROR', {

        token: 'uniquetoken',

      });

    }

    return err;

  },

  uploads: false,

});

...

客户端代码:


 ...

const ADD_CLAIM = gql`

  mutation addClaim($claim: ClaimInput!) {

    addClaim(claim: $claim) {

      id

    }

  }

`;

...


 const [addClaim, { data, error }] = useMutation(ADD_CLAIM);


 ...


 const onSubmit = async () => {

   try {

    debugger;

    const r = await addClaim({

      variables: {

        input: {

          id: insured.insured,

          date: '20/12/2020',

      ...

          therapy: treatment.treatments.map(treat => ({

            id: treat.treatId,

        ...

          })),

        },

      },

    });


    debugger;


    console.log('r', r);


    } catch (err) {

      debugger;

      setFormError(error ? error.message : err.message);

      console.log('Error:', err);

    }

  };


...



  if (error) {

    debugger;

    return <div>error</div>;

  }

我预计会收到自定义错误:“我们遇到了一些麻烦”。但是,无论我做什么,我都会得到:“响应不成功:收到状态代码 400”


鸿蒙传说
浏览 99回答 1
1回答

蓝山帝景

这是我的错误:error.networkError.result.errors什么没人知道?或者const errorLink = onError(({ graphQLErrors, networkError }) => {&nbsp; debugger;&nbsp; console.log(graphQLErrors);&nbsp; console.log(networkError);});const client = new ApolloClient({&nbsp; ...&nbsp; link: ApolloLink.from( [errorLink, ...]),&nbsp; &nbsp;&nbsp;});它也有效。是的,有时 GraphQL 是一头令人讨厌的野兽
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript