gpt4 book ai didi

javascript - 在返回之前使用函数

转载 作者:行者123 更新时间:2023-11-28 11:01:01 25 4
gpt4 key购买 nike

您好,我正在查看 React Redux 中的一个示例,在操作文件中我看到了这个函数

function login(email, password) {
return dispatch => {
dispatch(request({ email }));

userService.login(email, password)
.then(
data => {
dispatch(success(data.user));
history.push('/');
},
error => {
dispatch(failure(error));
dispatch(alertActions.error(error));
}
);
};

function request(user) { return { type: userConstants.LOGIN_REQUEST, user } }
function success(user) { return { type: userConstants.LOGIN_SUCCESS, user } }
function failure(error) { return { type: userConstants.LOGIN_FAILURE, error } }
}

很明显,这个函数正在返回调度文件来调用reducer我唯一不正确理解的部分是它如何在返回后定义一些函数并在返回中使用它。该功能运行正常,但如果我可以做一些改进,请告诉我。

最佳答案

尽管函数是在使用后声明的,但它仍然是合法的,如 function(不是箭头函数)和 var(不是 letconst) 被提升到 block 的开头,以便代码有效。

function login(email, password) {
function request(user) { return { type: userConstants.LOGIN_REQUEST, user } }
function success(user) { return { type: userConstants.LOGIN_SUCCESS, user } }
function failure(error) { return { type: userConstants.LOGIN_FAILURE, error } }

return dispatch => {
dispatch(request({ email }));

userService.login(email, password)
.then(
data => {
dispatch(success(data.user));
history.push('/');
},
error => {
dispatch(failure(error));
dispatch(alertActions.error(error));
}
);
};
}

MDN 有一个article of hoisting

关于javascript - 在返回之前使用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49433870/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com