所以这是我的情况。我有一个具有许多属性和方法的构造函数。这是属性:
var Brain = function(){
this.util = require('util');
this.fs = require('fs');
this.assert = require('assert');
this.Sequelize = require('sequelize');
this.JsonField = require('sequelize-json');
this.bcrypt = require('bcrypt-nodejs');
this.bodyParser = require('body-parser');
this.fileUpload = require('express-fileupload');
// Custom Modules
this.ModelsModule = require('./models');
this.TombModule = require('./tomb');
}
定义了一些方法来调用给定的回调并将数据传递给它,例如:
Brain.prototype.db_read = function(request, response, data, callback) {
var self = this;
self.ModelsModule[data.Model].findOne(data.where)
.then(function(obj) {
// console.log(obj);
callback(request, response, obj);
})
.catch(function(error){
console.log(error);
});
}
这就是事情 - 回调函数总是成为同一构造函数的另一种方法。这是另一种回调方法:
Brain.prototype.login = function(request, response, user) {
var self = this;
// console.log('form-data --- ', request.body);
if(user == null || user == undefined) {
console.log('Account Load: Failed');
return response.render( self.TombModule.pages['login'], {error: 'Invalid Credentials'} );
}
else {
// console.log(user.dataValues);
if( self.bcrypt.compareSync(request.body.pswrd, user.dataValues.pswrd) == false ) {
console.log('Account Load: Failed');
return response.render( self.TombModule.pages['login'], {error: 'Invalid Credentials'} );
}
console.log('Account Load: Successful');
request.session.you = {
id: user.dataValues.id,
f_name: user.dataValues.f_name,
m_initial: user.dataValues.m_initial,
l_name: user.dataValues.l_name,
icon: user.dataValues.icon,
background: user.dataValues.background,
email: user.dataValues.email,
phone: user.dataValues.phone,
fax: user.dataValues.fax,
uv: user.dataValues.uniqueValue
};
return response.redirect('/home');
}
}
在我的app.js中创建了一个新的Brain实例。
const RoutinesModule = require('./routines');
const brain = new RoutinesModule.Brain();
整个事件链从明确的POST路线开始:
app.post('/login', function(request, response){
var data = {
Model: 'Users',
where: {where: {email: request.body.email}}
}
brain.db_read(request, response, data, brain.login);
});
请注意,Brain.db_read的回调(最后一个参数)是Brain.login,它是同一构造函数的另一种方法。这是问题发生的地方。
当对/login
的POST请求命中app.js时,它将查询数据库并将结果提供给任何给定的函数来处理它,在本例中为Brain.login
在Brain.db_read()里面,var self = this;作品。它指向自己,大脑的实例。但是,当它调用Brain.login的回调时,Brain.login中的语句,var self = this;不起作用。它导致未定义,导致错误。
为什么会这样?为什么var self = this;在Brain.login里面导致未定义?
最终我要做的是创建一组主要函数来处理数据库操作(CRUD),而不是在每个单独的函数内部进行数据库操作,这可能是无限量的。
我可以轻松地在该函数定义中仅需要该模块,但我非常希望以动态,可伸缩和高效的方式访问其属性。
谢谢!
答案 0 :(得分:4)
你传递的方法是brain.login,它是一个没有所有者的函数。你只是传递函数参考。您需要brain.login.bind(brain)
。