[英]Javascript Callback Not Working as Intended
我试图确保checkteamexists
仅在checklogin
执行后才执行。 但是, checkteamexists
在checklogin
之后仍然起作用。
您可以将teamhome1_message
和teamhome2_message
想象为警报对话框。 他们弹出一条消息并没有返回任何内容。
function pushhistory(url, callback) {
history.push(url);
callback();
}
function checklogin(callback) {
if (!state.user.authenticated) {
pushhistory("/accounts/login", function() {
teamhome2_message()
});
}
callback();
}
function checkteamexists(teamname) {
if (teamname.toString().toLowerCase() == "team1") {
teamid = 1;
}
else {
pushhistory("/", function() {
teamhome1_message()
});
}
}
useEffect(() => {
checklogin(function() {
checkteamexists(teamname);
})
}, []);
checklogin
工作,因为 URL 变成/accounts/login
并提示teamhome2_message
。 但是,即使我不希望它出现, teamhome1_message
仍然出现。
我尝试在useEffect
挂钩(特定于 React)中指定回调,但回调似乎也不起作用。 谁能指出问题?
提前致谢。
@p2pdops 有正确的解决方案:将callback
function 放在 else 块中。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.