Nodejs异步可重用函数调用

时间:2019-05-28 20:45:26

标签: javascript node.js discord.js

在开发自己的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())。而且令我惊讶的是,等待完成的数据库查询显然不是一件事情……

1 个答案:

答案 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()
        }
      });
  })
}