[英]How to return a closure from an async function?
我正在尝试从异步 function 返回 function(闭包)。 到目前为止,我拥有事物space
的方式始终是 promise 而不是 function,即使它应该是一个闭包。
// ...
const [space, set_space] = React.useState(false);
React.useEffect(
() => {
API.SERVER(query, PAGE_SIZE)
.then(response => set_space(response));
},
[query]
);
React.useEffect(
() => {
console.log(space.constructor);
if (space) {
space(page)
.then(response => set_titles(Array.from(response.data)));
}
},
[space, page]
);
// ...
// ...
export default {
SERVER:async function(search, width)
{
if (!search) {
// return () => {};
search = DEFAULT_QUERY;
}
const all = (await axios.get(SEARCH_URL + `?search=${search}`)).data;
console.log(all);
const pages = chunk(all, width);
// function pager(results) {
// const dex = (results > width ? results / width : 0);
// const next = pages[dex];
// return axios.get(SEARCH_URL + `?fromids=${next}`);
// }
// return pager;
return function(results) {
const dex = (results > width ? results / width : 0);
const next = pages[dex];
return axios.get(SEARCH_URL + `?fromids=${next}`);
};
// return pager;
}
};
space.constructor
says it's a Promise, but it should be a function that returns axios' Promise, not a Promise it's self. 我无法真正改变 API 的设置方式,因为我需要保持索引客户端,然后通过更改空间参数来遍历它。
问题是, set_space
处理函数的方式与其他值不同。
这是因为 React 的 state 设置器可以接受一个回调,该回调接收以前的 state 作为参数。
但是,React 无法区分回调和恰好是 function 的值。 因此,React 将假定它是一个回调并调用它,然后将 state 设置为包含其返回值,即另一个 Promise。
要将 function 本身放入 state,您可以创建一个返回 function 的回调,如下所示:
API.SERVER(query, PAGE_SIZE)
.then(response => set_space(() => response));
嗯...您只想要一个 function 随叫随到的返回 promise? 那么useCallback
呢?
const triggerAsync = React.useCallback(
() => {
return API.SERVER(query, PAGE_SIZE)
.then(response => set_space(response))
},
[query]
);
然后triggerAsync
应该在你执行它时返回一个 promise
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.