在开发自己的Node.JS应用程序时遇到一些问题。我是这种代码架构的新手,对异步也不太好。
我当前在我的 index.js 脚本中有一个事件,要求另一个脚本 database.js 。该数据库脚本将处理我的应用程序中的每个数据库调用。
index.js
const db = require('database.js');
//Called when a userjoin the application, this is working well//
db.userJoinedFunction("username");
我打算在“ userjoinedFunction”中添加其他函数调用。例如:首先建立数据库连接->第二个检查用户是否已经在数据库中->如果不是3d,则创建用户条目-> 4,如果是,请返回欢迎消息。 由于必须多次建立数据库连接,因此我想在这些函数中重用一些代码,如下所示:
database.js
module.exports.userJoinedFuntion = userJoinedFunction
function userjoinedFunction(username){
Init_database_connection();
if(UserAlreadySignedup(username)){
WelcomeMessage(username);
}
else {
AddUserToDatabase(username);
}
}
但是显然我做错了,因为异步Node.js应用程序不能那么简单...我如何拥有这种可重用的体系结构?您是否可以阅读有关该主题的文章?
非常感谢您的帮助!
编辑2019年5月29日
在novomanish的回应下,我尝试了此操作:
async fonction run(){
await(call("number 1");
await Init_database_connection();
await(call("number 2");
}
async function call(text){
console.log(text);
}
async function Init_database_connection(){
db = new sqlite3.Database("path", sqlite.OPEN_READWRITE, (err) =>{
if(err){ console.log(err); }
else { console.log("DB Connected"); }
});
}
我的输出是:
- number one
- number two
- DB Connected
我检查了许多文章和文档,找不到在“主要功能”内重用功能的好方法(例如在我的示例中:功能run())。而且令我惊讶的是,等待完成的数据库查询显然不是一件事情……
答案 0 :(得分:1)
您需要在功能中进行异步/等待。因此,新代码如下所示:
async function Init_database_connection(){...}
...
async function userjoinedFunction(username){
await Init_database_connection();
if(await UserAlreadySignedup(username)){
return WelcomeMessage(username);
}
return AddUserToDatabase(username);
}
关于您的编辑,Init_database_connection应该返回一个等待工作的承诺,如下所示:
async function Init_database_connection(){
return new Promise((resolve, reject)=>{
db = new sqlite3.Database("path", sqlite.OPEN_READWRITE, (err) =>{
if(err){
console.log(err);
reject();
}else {
console.log("DB Connected");
resolve()
}
});
})
}