Gus*_*imo 4 javascript reactjs redux react-redux rtk-query
在下面的示例中,我尝试使用 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>
);
};
Run Code Online (Sandbox Code Playgroud)
这工作正常,问题是:
我想利用查询结果对象isLoading上的属性getUser,以便该<SpinnerIcon />组件在两个请求完成之前都可见。
事实上,该spinnerIcon组件仅在 API 调用期间显示login,因为我没有使用 React Hooks 来调用getUser查询,因此我没有可用于组件其余部分的isLoading属性。getUser
但如果我想使用 React Hooks 进行调用,我需要login事先获得突变的结果。
const [getUser, { isLoading: isUserLoading }] = useGetUserQuery(resultFromLoginMutation);
我不知道该怎么做。一个接一个,这样我就可以利用这两个isLoading属性。
您可以使用skipToken或skip选项:
const [login, { isLoading, data: resultFromLoginMutation, isSuccess }] = useLoginMutation();
const [getUser, { isLoading: isUserLoading }] = useGetUserQuery(resultFromLoginMutation, { skip: !isSuccess });
Run Code Online (Sandbox Code Playgroud)
或者
const [login, { isLoading, data: resultFromLoginMutation }] = useLoginMutation();
const [getUser, { isLoading: isUserLoading }] = useGetUserQuery(resultFromLoginMutation ?? skipToken);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8561 次 |
| 最近记录: |