Node.js,Express.js和sqllite3.js

时间:2017-01-03 17:30:16

标签: node.js express node-sqlite3

Node.js中的对象属性有问题。虽然在 test 对象中按预期设置了属性,但同样不适用于我的文章对象。我看到的区别是文章的功能是异步调用的。我必须承认我有点失落......

这是 app.js ,它实例化 test 对象和文章对象。

/**
 *  Load express.
 */
var express = require('express');
var app = express();

/**
 *  Load articles.
 */
var articles = require('./article.js');
var l_articles = new articles.Articles();

var test = require('./test.js');
var l_test = new test.Test();

app.get('/', function (req, res) {
    console.log(l_test.get());
    l_test.set('it is', 'midnight');
    console.log(l_test.get());

    articles.Articles.get(1);

    res.send('OK');
})

app.listen(3001, function () {
    console.log(l_test.get());
    l_test.set('goodbye', 'sunshine');
    console.log(l_test.get());

})

这是我相当简单的test.js:

var app = require('./app.js');

function Test() {
    this.timestamp = new Date();
    console.log(this.timestamp);
    this.attribute1 = 'hello';
    this.attribute2 = 'world';
}

Test.prototype.get = function() {
    console.log(this.timestamp);
    return (this.attribute1 + ' ' + this.attribute2);
}

Test.prototype.set = function(p_param1, p_param2) {
    console.log(this.timestamp);
    this.attribute1 = p_param1;
    this.attribute2 = p_param2;
}

module.exports = {
    Test: Test
};

这是我非常简单的文章.js:

var sqlite3 = require('sqlite3').verbose();
var app = require('./app.js');

function Articles(p_id) {
    this.timestamp = new Date();
    console.log(this.timestamp);
    this.db = new sqlite3.Database('./gescom.sqlite');
    if (p_id == undefined) {
        this.db.all('SELECT * FROM T_ARTICLE', this.load);
    } else {
        this.db.all('SELECT * FROM T_ARTICLE WHERE id = ' & p_id, this.load);
    }
}

Articles.prototype.load = function(p_err, p_rows) {
    console.log(this.timestamp);
    var ids = [];
    var articles = [];
    p_rows.forEach(function(p_row) {
        ids.push(p_row.ID);
        articles.push([p_row.ID, p_row.SHORT_NAME]);
    });
    this.ids = ids;
    this.articles = articles;
    console.log(this.ids.length + ' articles loaded from database.');
}

Articles.prototype.get = function (p_id) {
    console.log(this.timestamp);
    var l_return;
    if ((this.ids == undefined) || (this.articles == undefined)) {
        console.log('No articles loaded from database.');
    } else {
        console.log(this.ids.length + ' articles loaded from database.');
        if (p_id == undefined) {
            l_return = this.articles;
        } else {
            if (this.ids.indexOf(p_id) != undefined) {
                l_return = (this.articles[this.ids.indexOf(p_id)]);
            } else {
                l_return = undefined;
            }
        }
    }
    return l_return;
}

module.exports = {
    Articles: Articles
};

0 个答案:

没有答案