【发布时间】:2019-09-09 09:02:28
【问题描述】:
我正在尝试进行突变,但我不断收到有关 React 端数据为空的错误。但是,如果我在 GraphQL 控制台中尝试相同的突变,它就会起作用。另外,我知道端点正在工作,因为我可以毫无问题地查询数据。
一切
服务器代码(解析器):
async signup(parent, args, ctx, info) {
// lowercase their email
args.email = args.email.toLowerCase();
// hash their password
const password = await bcrypt.hash(args.password, 10);
// create the user in the database
const user = await ctx.db.mutation.createUser({
data: {
...args,
password,
}
}, info);
return user;
}
突变(反应端)
mutation signupUser($email: String!, $password: String!, $name: String!) {
signup(email: $email, password: $password, name: $name) {
__typename
id
email
password
name
}
}
TypeError: Cannot read property 'data' of undefined
at Mutation._this.onMutationCompleted (react-apollo.esm.js:477)
at react-apollo.esm.js:434
这也是我在组件上的 Mutation 的 sn-p
<Mutation
mutation={signUpUserMutation}
onCompleted={(user) => {
handleClose();
}}
onError={(error) => {
console.log(error)
setOpen(true);
}}
>
{signup => (
<Form
onSubmit={async (values, { setSubmitting }) => {
await signup({
variables: {
name: values.name,
email: values.email,
password: values.password,
},
});
setSubmitting(false);
}}
>
{({
values, errors, handleChange, handleBlur, isSubmitting,
}) => (
【问题讨论】:
-
我想通了。我认为这是因为我没有 WebSocket 连接。 Idk,不管怎样,它解决了我的问题。