Sails.js 如何在sails中恢复生命周期回调?

Sails.js 如何在sails中恢复生命周期回调?,sails.js,lifecycle,waterline,Sails.js,Lifecycle,Waterline,在测试模型创建之后,我注意到没有调用生命周期回调,在阅读Waterline的文档时,我发现: 注意:使用自定义适配器方法时,不使用水线的功能。您不再像使用定义的Waterline方法时那样获得生命周期回调和验证 尽管如此,我并没有故意使用自定义适配器方法,这是我在文档中找到的关于禁用生命周期回调的唯一参考 对于config/*中的任何文件,我应该有什么标准/设置来绝对确保不禁用生命周期回调 以下是我使用的唯一生命周期回调未被调用的模型副本: /** * User.js * */ var bcr

在测试模型创建之后,我注意到没有调用生命周期回调,在阅读Waterline的文档时,我发现:

注意:使用自定义适配器方法时,不使用水线的功能。您不再像使用定义的Waterline方法时那样获得生命周期回调和验证

尽管如此,我并没有故意使用自定义适配器方法,这是我在文档中找到的关于禁用生命周期回调的唯一参考

对于config/*中的任何文件,我应该有什么标准/设置来绝对确保不禁用生命周期回调

以下是我使用的唯一生命周期回调未被调用的模型副本:

/**
* User.js
*
*/

var bcrypt = require('bcrypt');

module.exports = {
attributes: {
'email': {
        type: 'email',
        required: true,
        unique: true
},

'username': {
        type: 'string',
        required: true,
        unique: true,
        minLength: 5,
        maxLength: 16
},

'password': {
        type: 'string',
        required: true
},

'family': {
        model: 'family'
},

'lastlogin': {
        type: 'datetime',
        defaultsTo: function() {return new Date().toISOString();}
},

    beforeCreate: function(obj, cb) {
        console.log("In beforeCreate");
        bcrypt.hash(obj.password, 10, function(err, hash) {
            if (err) {
                console.log(err);
                return cb(err);
            }

            obj.password = hash;
            cb();
        });
    }
  }
};`

回调必须位于exports对象上,而不是属性

/**
* User.js
*
*/

var bcrypt = require('bcrypt');

module.exports = {
attributes: {
'email': {
        type: 'email',
        required: true,
        unique: true
    },

'username': {
        type: 'string',
        required: true,
        unique: true,
        minLength: 5,
        maxLength: 16
    },

'password': {
        type: 'string',
        required: true
    },

'family': {
        model: 'family'
    },

'lastlogin': {
        type: 'datetime',
        defaultsTo: function() {return new Date().toISOString();}
    },

},

beforeCreate: function(obj, cb) {
    console.log("In beforeCreate");
    bcrypt.hash(obj.password, 10, function(err, hash) {
        if (err) {
            console.log(err);
            return cb(err);
        }

        obj.password = hash;
        cb();
    });
   }

};

除非使用自定义方法,否则该注释不应有任何意义。您正在使用自定义方法吗?您可能想发布一个代码示例。据我所知不是这样,但我添加了它,因为它是我在Waterline文档中找到的关于禁用的生命周期回调的唯一参考。我们所有人都会遇到这种情况。