在下面的示例中,我尝试使用 React 和 Redux Toolkit 创建一个简单的登录/身份验证组件。
const Login = () => {
const dispatch = useDispatch();
const [login, { isLoading }] = useLoginMutation();
const [loginData, setLoginData] = useState({
email: '',
password: '',
});
const loginHandler = async () => {
try {
const result = await login({
email: loginData.email,
password: loginData.password,
}).unwrap();
const { token, userId } = result;
const { data } = await dispatch(
backendApi.endpoints.getUser.initiate({ token, userId })
);
dispatch(
setCredentials({
user: {
email: data.user.email,
id: data.user.id,
name: data.user.name,
type: data.user.type,
},
token,
})
);
} catch (err) {
console.log(err);
}
};
return (
<Space>
{isLoading ? (
<SpinnerIcon />
) : (
// setLoginData and loginHandler are set and used here
// Standard React code: Input onChange -> setLoginData / Submit button onClick -> loginHandler
// (nothing special, code shortened for the sake of readability)
<FormWithEmailPasswordInputsAndButton />
)}
</Space>
);
};
这工作正常,问题是:
我想利用查询结果对象isLoading
上的属性,getUser
以便在<SpinnerIcon />
完成两个请求之前,组件都是可见的。
实际上,该spinnerIcon
组件仅在login
API 调用期间显示,因为我没有使用 React Hooks 来调用getUser
查询,因此我没有该组件的其余部分可用的isLoading
属性。getUser
但是,如果我想使用 React Hooks 进行调用,我需要login
事先获得突变的结果。
const [getUser, { isLoading: isUserLoading }] = useGetUserQuery(resultFromLoginMutation);
我不知道该怎么做。一个接一个,这样我就可以利用这两个isLoading
属性。