Подтвердить что ты не робот

Как сделать sequelize имеет много связей в нижнем регистре в представлениях

Все работает здесь. Единственная проблема заключается в том, что в моем файле handlebars мне нужно выполнить следующие задачи:

this.Tasks

Я предпочел бы, чтобы он выглядел так:

this.Tasks

Как я могу настроить Sequelize для этого?

Вот как выглядит корневой маршрут моего приложения (он отображает файл index.handlebars)

приложение для управления проектами

мой маршрут:

router.get('/', function(req, res) {
  models.Person.findAll({
    include: [ models.Task ]
  }).then(function(people) {
    res.render('index', {
      user_id: req.session.user_id,
      email: req.session.user_email,
      logged_in: req.session.logged_in,
      people: people
    });
  });
});

мой файл index.handlebars:

  {{#each people}}
    <li>
      {{this.name}}
      {{#if ../logged_in}}
        <a href="/people/{{this.id}}/destroy"> destroy</a>
      {{/if}}
      <ul>
        {{#if ../logged_in}}
          <li>
            <form action="/people/{{this.id}}/tasks/create" method="POST" style="display: inline">
              <input type="text" name="task" placeholder="add task here">
              <input type="submit" value"assign task">
            </form>
          </li>
        {{/if}}

        {{#each this.Tasks }}
          <li>
            {{this.task}}
            {{#if ../../logged_in}}
              <a href="/people/{{this.person_id}}/tasks/{{this.id}}/destroy">destroy</a>
            {{/if}}
          </li>
        {{/each}}
      </ul>
    </li>
  {{/each}}

миграция таблиц моих людей:

"use strict";

module.exports = {
  up: function(queryInterface, Sequelize) {
    return queryInterface
      .createTable('people', {
        id: {
          type: Sequelize.INTEGER,
          autoIncrement: true,
          primaryKey: true
        },
        name: Sequelize.STRING,
        created_at: Sequelize.DATE,
        updated_at: Sequelize.DATE
      });
  },

  down: function(queryInterface, Sequelize) {
    return queryInterface
      .dropTable('people');
  }
};

миграция таблицы задач:

"use strict";

module.exports = {
  up: function(queryInterface, Sequelize) {
    return queryInterface
      .createTable('tasks', {
        id: {
          type: Sequelize.INTEGER,
          autoIncrement: true,
          primaryKey: true
        },
        person_id: {
          type: Sequelize.INTEGER
        },
        task: Sequelize.STRING,
        created_at: Sequelize.DATE,
        updated_at: Sequelize.DATE
      });
  },

  down: function(queryInterface, Sequelize) {
    return queryInterface
      .dropTable('tasks');
  }
};

my person.js модель:

"use strict";

module.exports = function(sequelize, DataTypes) {
  var Person = sequelize.define("Person", {
    name: DataTypes.STRING
  }, {
    underscored: true,
    freezeTableName: true,
    tableName: 'people',
    classMethods: {
      associate: function(models) {
        Person.hasMany(models.Task)
      }
    }
  });

  return Person;
};

my task.js модель:

"use strict";

module.exports = function(sequelize, DataTypes) {
  var Task = sequelize.define("Task", {
    task: DataTypes.STRING
  }, {
    freezeTableName: true,
    tableName: 'tasks',
    classMethods: {
      associate: function(models) {
        Task.belongsTo(models.Person, {
          onDelete: "CASCADE",
          foreignKey: {
            allowNull: false
          }
        });
      }
    }
  });

  return Task;
};
4b9b3361

Ответ 1

Вместо использования строчного имени для sequelize.define вы также можете установить имя через псевдоним, используя опцию "как". Ex. Task.belongsTo(models.Person, {as: 'task'});. Кроме того, вы можете установить псевдоним в самой функции определения. Ex. sequelize.define("Task", attributes, { name : { singular: "task", plural: "tasks" })

Ответ 2

определить имя модели в нижнем регистре как

var Task = sequelize.define( "task", {

Ответ 3

my task.js модель:

module.exports = function(sequelize, DataTypes) {
var Task = sequelize.define("Task", {

Просто укажите

var task = sequelize.define("task", {

Разве это не решает вопрос?