{ ref.child("status").on("value", snapshot -6ren">
gpt4 book ai didi

javascript - async/await 在没有 promise 完成的情况下解决

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

const handleStatus = (ref, error = "Unknown error") => {
ref.child("status").on("value", snapshot => {
const status = snapshot.val();
if (status === SUCCESS) {
ref.child("status").off();
return Promise.resolve(error);
} else if (status !== PENDING) {
return Promise.reject(error);
}
});
};

export default class Database {
/**
* @desc create character
* @type {Promise}
*/
static create = async (uid = "", username = "", gender = "", race = "") => {
try {
const ref = database.ref(`/void/create/${uid}`);
await ref.set({ username, gender, race, status: PENDING });
await handleStatus(ref, "Unable to create character, please try again latter");
} catch (e) {
return Promise.reject("Username already taken");
}
};
}

我在使用上述代码时遇到问题,特别是 handleStatusDatabase.create() 函数中立即解决。我希望它仅在满足 if (status === SUCCESS) (或 else 语句)时才能解析,这通常需要一些时间 .on("value")函数(如果您感兴趣,但与问题无关,则来自 firebase)。目前它立即解决,if 语句中没有任何内容被执行,并且 Database.create() 仍然返回,我不知道为什么。

最佳答案

您似乎想要构造一个在事件上解决或拒绝的 Promise。这根本不是您的代码所做的。

handleStatus 实际上不会返回任何内容,因为其中没有 return 语句。唯一的 return 语句位于事件处理程序中,并在其中被丢弃。另外,你对Promise.resolve和Promise.reject有误解:它们被用来在调用时创建新的Promise实例;再说一次,这不是你想要的。

您实际上想要创建一个新的 Promise 并返回它:

const handleStatus = (ref, error = "Unknown error") => {
return new Promise((resolve, reject) => {
ref.child("status").on("value", snapshot => {
const status = snapshot.val();
if (status === SUCCESS) {
ref.child("status").off();
resolve(error); // is this really what you mean?
} else if (status !== PENDING) {
reject(error);
}
});
});
};

关于javascript - async/await 在没有 promise 完成的情况下解决,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43054863/

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