编辑 - 问题标题已经过编辑,以反映问题的真实性质
我正在尝试重构我的node.js应用程序代码,并更好地利用OOP原则。在重构之前,mysql驱动程序和连接(池)位于路由逻辑等之上的主app.js文件的顶部。我现在已经创建了下面的文件,并在主app.js文件中导入了这个并尝试使用该课程。但是该类无法实例化。我是JavaScript类的新手,所以我可能犯了一个简单的错误。谁能在这里看到错误?
const mysql = require('mysql');
class Database {
constructor(maxConnections) {
this._pool = mysql.createPool({
connectionLimit: maxConnections,
host: '',
user: '',
password: '',
database: ''
});
}
get Pool() {
return this._pool;
}
// static ExecuteSQL(sql, callback) {
// this.Pool.getConnection(function (err, connection) {
// connection.query(sql, function (err, rows, fields) {
// if (err) {
// callback(err, null, null);
// } else {
// callback(null, rows, fields);
// }
// connection.release();
// });
// });
// }
static Format(sql, args) {
return mysql.format(sql, args);
}
}
module.exports = {
Database,
}
数据库逻辑在重构代码之前工作,所以我认为这是与JavaScript类有关的错误。
答案 0 :(得分:0)
问题不准确,但这是解决方案:
问题是我试图调用db.Format(),其中db是Database的一个实例。看来,使用JavaScript,您无法从实例中调用静态成员。修复是调用Database.Format(),其中Database是'静态'类定义