mysql - Node.js ES6 类私有(private)存储

标签 mysql node.js ecmascript-6 es6-class

我正在使用 ES6 通过 Node.js 应用程序类进行构建。我想创建一个数据库类,所以我执行了以下操作:

"use strict"

var ini = require('node-ini');
var mysql = require('mysql');
let _db = new WeakMap();

// Class de base pour la base de donnée 
class Db{
    constructor () {
        ini.parse('../config/settings.ini', function(err,data){
            if(err) {
                console.log(err);
                return;
            } else {
                _db.set(this, mysql.createConnection({
                    host     : data.database_MYSQL.host,
                    user     : data.database_MYSQL.username,
                    password : data.database_MYSQL.password,
                    database : data.database_MYSQL.schema
                }));
            }
        });
    }
}

module.exports = Db;

这是我第一次尝试存储私有(private)变量,我在网上寻找解决方案。我找到了我尝试实现的 Weakmap 解决方案。但是MySQL连接不会将其与以下源代码一起存储。我有这个输出:

_db.set(this, mysql.createConnection({
                    ^
TypeError: Invalid value used as weak map key
    at WeakMap.set (native)
    at D:\supervision\application\class\db.js:15:21
    at D:\supervision\application\node_modules\node-ini\node-ini.js:168:12
    at FSReqWrap.readFileAfterClose [as oncomplete] (fs.js:380:3)

那么该如何处理呢?

编辑:

以下是调用者如何知道它何时初始化的:

var db;

function instantiateDb(callback){
        db = new db_connector();
        callback(db);
}

instantiateDb(function(db){
    db.connectDatabase();
})

最佳答案

this 在回调中是undefined,它不是引用Db的实例,因此你得到那个错误。看看How to access the correct `this` inside a callback?了解如何解决这个问题。

但是,这里有一个更大的问题:您正在构造函数内执行异步操作。这意味着任何想要使用 Db 实例的人都无法知道它何时会完全初始化。

解决此问题的更好方法是使用一个静态异步方法,该方法返回一个新的、完全初始化的 Db 实例:

class Db {
  static get() {
    return new Promise((resolve, reject) => {
      ini.parse('../config/settings.ini', function(err,data){
        if (err) {
          reject(err);
        } else {
          resolve(new Db(data));
        }
      });
    });
  }

  constructor (data) {
    _db.set(this, mysql.createConnection({
      host     : data.database_MYSQL.host,
      user     : data.database_MYSQL.username,
      password : data.database_MYSQL.password,
      database : data.database_MYSQL.schema
    }));
  }
}

然后可以用作

Db.get().then(db => {
  db.connectDatabase();
});

关于mysql - Node.js ES6 类私有(private)存储,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43588946/

相关文章:

mysql - mysql中最新列的总和部分

php - 根据输出格式编写查询

php - 使用 Webpack Express 和 React 进行服务器端渲染

javascript - 在 es6 类上创建私有(private)成员

javascript - 尝试用 Jest 制作一个简单的 Axios 模拟

mysql - DATE_FORMATE() 或 MONTH(),YEAR() 中哪一个更好

mysql - 从数据库导入表

node.js - 如何在fs.createWriteStream中创建动态模板?

javascript - 如何将嵌套 JSON 对象的所有键值移动到 Node.js 中的父级

javascript - 基于对象属性的数组过滤