javascript - Sequelize 模型自定义方法返回未定义

标签 javascript methods model undefined sequelize.js

在我的应用程序上,我有用户,有些用户是医生,有些是牙医,有些是营养师,当我使用时,我想发送一个包含用户和用户数据的 json,该数据基于两列用户(model_id 和 model),我尝试使用名为 morphTo 的自定义方法来实现它,所以我有一个名为 users

的模型
module.exports = function(sequelize, DataTypes) {
  var user = sequelize.define('users', {
  email: {type: Sequelize.STRING, field: 'email'},
  password: Sequelize.STRING,
  name: Sequelize.STRING,
  company_id: Sequelize.INTEGER,
  rg: Sequelize.STRING,
  cpf: Sequelize.STRING,
  birth_date: Sequelize.STRING,
  sex: Sequelize.STRING,
  address: Sequelize.STRING,
  number: Sequelize.STRING,
  complement: Sequelize.STRING,
  neighborhood: Sequelize.STRING,
  city: Sequelize.STRING,
  cep: Sequelize.STRING,
  uf: Sequelize.STRING,
  obs: Sequelize.STRING,
  status_id: Sequelize.INTEGER,
  model_id: Sequelize.INTEGER,
  model: Sequelize.STRING,
  deleted_at: Sequelize.STRING,
  created_at: Sequelize.STRING,
  updated_at: Sequelize.STRING,
  }, {timestamps:false, attributes: { exclude : [ 'password' ]},
      classMethods: {
        associate: function(models) {
          user.belongsToMany(models.groups, {
          through: {
          model: models.user_groups
          }, foreignKey:'user_id', as: 'groups'}),
          user.belongsToMany(models.permissions, {
          through: {
          model: models.user_permissions
          }, foreignKey:'user_id', as: 'permissions'})
        },
        morphTo: function(models, model_id, model){ 
          if(model == 'medics'){
            models.medics.findById(model_id).then(function(results) {

              return results;

            });

          }else if(model == 'employees'){
            models.employees.findById(model_id).then(function(results) {

              return results;

            });
          }
        }
      }});

  return user;

}

在我的资源上我有这个

models.users.findById(req.params.id).then(function(results) {
        if(results)
            console.log(models.users.morphTo(models, results.dataValues.model_id, results.dataValues.model));
        else
            res.status(204).send();
    });

我的控制台正在运行查询,但返回结果为“未定义”

Executing (default): SELECT `id`, `crm` FROM `medics` AS `medics` WHERE `medics`.`id` = 1

我忘记了什么?

最佳答案

我认为你的 promise 有问题:

console.log(models.users.morphTo(models, results.dataValues.model_id, results.dataValues.model));

这是一个异步调用。您不应该立即期待答案,而应该期待一个 promise 。

试试这个:

models.users.findById(req.params.id).then(function(results) {
    if(results) {
        models.users.morphTo(models, results.dataValues.model_id, results.dataValues.model).then(function(result) {
            console.log('This is your result:', result);                
        });
    } else {
        res.status(204).send();
    }
});

您可以简化模型声明:

morphTo: function(models, model_id, model){ 
    if(model == 'medics'){
        return models.medics.findById(model_id);
    }else if(model == 'employees'){
        return models.employees.findById(model_id);
    }
}

关于javascript - Sequelize 模型自定义方法返回未定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36865970/

相关文章:

javascript - react : Edit and Delete from a pop-up menu on a list item

java - Java 是 "pass-by-reference"还是 "pass-by-value"?

java - 从同一个类中的另一个方法调用 main 方法

java - 在运行时查看方法调用 java jar 文件

r - igraph'ing 嵌套模型

JavaScript 在粘贴到控制台时工作正常,而不是作为书签

javascript - 在 Angular 垫表中根据 rowIndex 和 columnIndex 插入数据

javascript - 在vuejs中传递 Prop 数据

javascript - 主干-共享模型

ruby-on-rails - Rails 与没有模型的表的关联