JavaScript - 从实例调用静态成员

时间:2017-08-23 16:18:04

标签: javascript mysql node.js class oop

编辑 - 问题标题已经过编辑,以反映问题的真实性质

我正在尝试重构我的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类有关的错误。

1 个答案:

答案 0 :(得分:0)

问题不准确,但这是解决方案:

问题是我试图调用db.Format(),其中db是Database的一个实例。看来,使用JavaScript,您无法从实例中调用静态成员。修复是调用Database.Format(),其中Database是'静态'类定义