Vue.js,异步等待函数 return 空结果
Vue.js, async await functions return empty results
js 项目,我需要使用 await/async 从我的 API.
获取数据
我的代码
const logsFc = async () => {
let logs = [];
for (let i = 0; i < this.data.length; i++) {
const formData = new FormData();
const getLogsFc = () => {
getLogs.request(new URLSearchParams(formData), (response) => {
if (response.status >= 200 && response.status < 300) {
localConsoleLog('getLogs', response);
return response.data.data;
}
});
};
let data = await getLogsFc();
console.warn(data);
logs.concat(data);
}
return logs;
};
但是在得到响应之前返回日志。
babel.config.js
module.exports = {
presets: [
[
'@babel/preset-env',
{
useBuiltIns: 'usage',
corejs: 3.6,
modules: false,
},
],
],
};
"vue": "^2.6.0"
我做错了什么?
不要 运行 request
的回调只是 return 响应 :
const getLogsFc = async () => {
let response = await getLogs.request(new URLSearchParams(formData));
if (response.status >= 200 && response.status < 300) {
localConsoleLog('getLogs', response);
return response.data.data;
}
};
let data = await getLogsFc();
js 项目,我需要使用 await/async 从我的 API.
获取数据我的代码
const logsFc = async () => {
let logs = [];
for (let i = 0; i < this.data.length; i++) {
const formData = new FormData();
const getLogsFc = () => {
getLogs.request(new URLSearchParams(formData), (response) => {
if (response.status >= 200 && response.status < 300) {
localConsoleLog('getLogs', response);
return response.data.data;
}
});
};
let data = await getLogsFc();
console.warn(data);
logs.concat(data);
}
return logs;
};
但是在得到响应之前返回日志。
babel.config.js
module.exports = {
presets: [
[
'@babel/preset-env',
{
useBuiltIns: 'usage',
corejs: 3.6,
modules: false,
},
],
],
};
"vue": "^2.6.0"
我做错了什么?
不要 运行 request
的回调只是 return 响应 :
const getLogsFc = async () => {
let response = await getLogs.request(new URLSearchParams(formData));
if (response.status >= 200 && response.status < 300) {
localConsoleLog('getLogs', response);
return response.data.data;
}
};
let data = await getLogsFc();