0

嘿,基本上我在写一个网络应用程序,我喜欢在 app.js 中处理所有事情,所以我确实制作了一个名为 event.js 的脚本来处理页面功能,我只是导出它们,我的问题是它工作得很好,直到我做了需要从数据库中列出一些东西,我知道它不是那么优雅,但我确实尝试了 whit 事件和 whit 回调......这是我的代码 whitout 调用或任何东西,在这种情况下,它第一次无法加载任何内容,用于第二次渲染他有价值观..

//app.js
app.get('/page',events.page);   

//event.js
exports.page = function(req,res,next) {
  if (name == 'Accounting'){
    if (req.session.ulevel == 0) {
      name='Index';
      mg='notauthed';
      show='nothing';
    } else {     
      show='accinfo';  
      name == 'Accounting';  
      console.log('asdasdasdinfoooo');
      pg.connect(connectionString, function(err, client) {
        client.on('drain', client.end.bind(client));
        client.query('SELECT * FROM newtest5 where id=$1',['uid']
        , function(err,results){ 
          dlogin=results.rows[0].username;
          did=results.rows[0].id;
          dpwd=results.rows[0].password;
          demail=results.rows[0].email;     
          dregdate=results.rows[0].regdate;
          drule=results.rows[0].rights;
          dmoney=results.rows[0].balance;
          // move render here
        });
      });

      res.render('index', { 
        title: name,
        dplay:show,
        dbname:dlogin,
        dbid:did,
        dbpwd:dpwd,
        dbrule:drule,
        dbregd:dregdate,
        dbemail:demail,
        username:req.session.user,
        uid:req.session.uid,
        user:req.session.user,
        right:req.session.ulevel,
        content:contents[name],
        msg:msgs[mg]
      }), console.log('data:'+dlogin);
    }
  } 
} 

我的对象是当这个代码中的名称是会计时,我喜欢渲染一个页面,加载的信息,而不是现在它的工作,基本上我只是在应用程序 js 和 evry 函数中路由,并且渲染也完全导出从事件js,它基本上工作得很好,只是问题是..render在数据库读取完成之前运行..我需要让render等待数据读取结束,然后执行render。

4

2 回答 2

1

您的缩进使您无法看到发生了什么。我重新缩进了它。当你打电话时pg.connect(str, callback),你会在你定义的地方传递一个回调dlogin等等。但是在你打电话给你之后,你pg.connect会立即打电话res.render()!JavaScript 引擎不等待任何人。正确的方法是放在res.render()最里面的回调中。这将确保在您实际定义dlogin等之前不会发送响应。

res.locals如果要设置要使用的翡翠变量(或可能是其他模板引擎),也可以使用

//app.js
app.get('/page',events.page);   

//event.js
exports.page = function(req,res,next) {
  if (name == 'Accounting'){
    if (req.session.ulevel == 0) {
      name='Index';
      mg='notauthed';
      show='nothing';
    } else {     
      show='accinfo';  
      name == 'Accounting';  
      console.log('asdasdasdinfoooo');
      pg.connect(connectionString, function(err, client) {
        client.on('drain', client.end.bind(client));
        client.query('SELECT * FROM newtest5 where id=$1',['uid']
        , function(err,results){ 
          res.locals.dlogin=results.rows[0].username;
          res.locals.did=results.rows[0].id;
          // etc...
          console.log('data:'+res.locals.dlogin); 
          // ... it gets set here, when the callback is finally run
          res.render('index');
        });
      });

      console.log('data:'+res.locals.dlogin);  
      // this will be undefined after defining the callback, until the callback is run
      // pg.connect() has been run, but not its callback, yet
    }
  } 
} 
于 2013-05-20T14:34:59.457 回答
0

如果您尝试从 event.js 中访问您在 app.js 中创建的数据库对象,您可以将数据库传递给事件:

//app.js
var db = require('someDB');
var event = require('./event.js')(db);
event.someFunction(function(err, data){ 
  console.log(data);
});

//event.js
module.exports = function(db){
  var event = {};

  event.someFunction = function(callback){
    db.fetch('someone', function(err, data){
      callback(err, data);
    });
  };

  return event;
}
于 2013-05-19T19:16:38.227 回答