未处理的拒绝(TypeError):无法读取未定义的属性“扩展”。(GraphQL)
2020-12-19
1934
我正在使用 GraphQL 和 MERNG,并收到以下错误:未处理的拒绝(TypeError):无法读取未定义的属性“extensions”。请帮帮我。我还重新安装了 graphql。这是发生错误的行:setErrors(err.graphQLErrors[0].extensions.exception.errors);
这是我的 Register.js 文件:
import React, {
useState
} from 'react'
import {
Button,
Form
} from 'semantic-ui-react'
import gql from 'graphql-tag'
import {
useMutation
} from '@apollo/react-hooks'
function Register() {
const [errors, setErrors] = useState({});
const [values, setValues] = useState({
username: '',
email: '',
password: '',
confirmPassword: ''
})
const onChange = (event) => {
setValues({ ...values,
[event.target.name]: event.target.value
});
}
const [addUser, {
Loading
}] = useMutation(REGISTER_USER, {
update(proxy, result) {
console.log(result);
},
onError(err) {
console.log(err.graphQLErrors[0].extensions.exception.errors);
setErrors(err.graphQLErrors[0].extensions.exception.errors);
},
variables: values
})
const onSubmit = (event) => {
event.preventDefault();
addUser();
}
return ( <
div className = "form-container" >
<
Form onSubmit = {
onSubmit
}
noValidate >
<
h1 > Register < /h1> <
Form.Input label = "Username"
placeholder = "Username"
name = 'username'
type = "text"
value = {
values.username
}
onChange = {
onChange
}
/> <
Form.Input label = "Email"
placeholder = "Email"
name = 'email'
type = "email"
value = {
values.email
}
onChange = {
onChange
}
/> <
Form.Input label = "Password"
placeholder = "Password"
name = 'password'
type = "password"
value = {
values.password
}
onChange = {
onChange
}
/> <
Form.Input label = "Confirm Password"
placeholder = "Confirm Password"
name = 'confirmPassword'
type = "password"
value = {
values.confirmPassword
}
onChange = {
onChange
}
/> <
Button type = "submit"
primary >
Register <
/Button> <
/Form> {
Object.keys(errors).length > 0 && ( <
div className = "ui error message" >
<
ul className = "list" > {
Object.values(errors).map(value => ( <
li key = {
value
} > {
value
} < /li>
))
} <
/ul> <
/div>
)
} <
/div>
)
}
const REGISTER_USER = gql `
mutation register(
$username: String!
$email: String!
$password: String!
$confirmPassword: String!
){
register(
RegisterInput: {
username: $username
email: $email
password: $password
confirmPassword: $confirmPassword
}
){
id email username createdAt token
}
}
`
export default Register;
3个回答
这清楚地表明
err.graphQLErrors[0]
未定义,如果您不想要该未定义错误,您可以执行以下操作:
setErrors(err&&err.graphQLErrors[0]?err.graphQLErrors[0].extensions.exception.errors:{});
Sakshi
2020-12-19
将您的
setErrors
从
setErrors(err.graphQLErrors[0].extensions.exception.errors);
更改为
setErrors(err.graphQLErrors[0].extensions.errors);
Tosin Adeniji
2021-09-14
你可以
console.log(err);
看看是什么错误,可能是网络错误。
Dikembe Mutombo
2022-10-12