Политика конфиденциальностиКонтактыО сайтеОтзывыGitHubDonate
© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB

Ruby on Rails - Генерирование ресурсов

Ruby, Ruby on Rails, user, web, генерирование

После того, как удалось получить в предыдущей статье рабочий вариант веб-приложения на Ruby, пошёл разбираться дальше с разработкой и генерированием ресурсов, а также с изучением архитектуры веб-приложений Ruby on Rails. Благо данный фреймворк использует паттерн MVC, который также используется в  Qt, поэтому в целом с пониманием архитектуры проблем возникнуть не должно.

В процессе поиска источников информации в стиле "Ruby для чайников", "Ruby за 21 день" и т.д. я натолкнулся, по-видимому, на весьма замечательный ресурс , который является переводом книги Ruby on Rails Tutorial by Michael Hartl. Первое впечатление от книги оказалось положительным. Так что дальнейшее самообучение, пожалуй, буду проводить по этому ресурсу.

Из первых плюсов, которые обнаружил, так это упоминание среды разработки RubyMine от JetBrains. Я уже знаком с такими продуктами, как WebStorm, PHPStorm, Intellij IDEA и основанной на ней AndroidStudio, поэтому на данный момент остановил свой выбор на этой среде разработки. Что странно Google по запросам Ruby IDE и аналогичным, не показал информации об этой среде разработки, видимо ещё не раскрутились.

В общем полон мир открытий чудных для новичка. Ну а теперь приступим непосредственно к генерированию ресурсов, которые будут работать на основе MVC паттерна.

Генерирование ресурсов USER

В выше названной книге предлагается после создания первого тестового приложения добавить в базу данных таблицу с записями пользователей, а в проект нашего новоиспеченного тестового блога все необходимые для работы с пользователями файлы, то есть страницы для добавления, удаления, просмотра списка пользователей.

То есть следующие файлы:

  • db/migrate/20130305221714_create_users.rb
  • app/models/user.rb
  • test/models/user_test.rb
  • test/fixtures/users.yml
  • app/controllers/users_controller.rb
  • app/views/users
  • app/views/users/index.html.erb
  • app/views/users/edit.html.erb
  • app/views/users/show.html.erb
  • app/views/users/new.html.erb
  • app/views/users/_form.html.erb
  • test/controllers/users_controller_test.rb
  • app/helpers/users_helper.rb
  • test/helpers/users_helper_test.rb
  • app/views/users
  • app/views/users/index.json.jbuilder
  • app/views/users/show.json.jbuilder
  • app/assets/javascripts/users.js.coffee
  • app/assets/stylesheets/users.css.scss
  • app/assets/stylesheets/scaffolds.css.scss

Причем все эти файлы генерируются автоматически с помощью команды scaffold, которая формирует весь необходимый программный код. Итак, необходимо в базу данных добавить таблицу со следующего вида:

  • id - уникальный идентификатор строки, тип данных integer;
  • name - имя пользователя, тип данных string;
  • email - его почтовый адрес, тип данных string.

Для этого переходим в директорию блога с автоматически генерированным содержанием в прошлой статье (у меня это C:\Sites\blog) и выполняем следующую команду:

$ rails generate scaffold User name:string email:string

Как видите, здесь не фигурирует id записей, поскольку он генерируется автоматически. Параметр User - отвечает за имя таблицы, причем в итоге генерируется таблица под названием users. Также в результате выполнения данного программного кода будет добавлена ещё пара полей в таблице. Убедиться в этом можно заглянув в базу данных SQLite, а сделать это можно с помощью программы SQLiteStudio , кстати рекомендую как очень удобный инструмент. Эти дополнительными полями будут дата создания и дата обновления.

Но просмотреть эти данные в базе данных таким образом Вы поначалу не сможете. Поскольку шаблон был создан, но таблица не была добавлена в базу данных. Для этого её необходимо обновить, то есть мигрировать дополнения в базу данных следующие командой:

$ bundle exec rake db:migrate

Признаюсь, у меня это сразу не сработало, поскольку я забыл установить bundle. Исправляем эту ситуацию командой:

$ gem install bundler

Ну а после миграции, запускаем сервер:

$ rails server

И пробуем поработать с пользователями. Для этого необходимо перейти по следующим адресам в браузере:

URL Действие Назначение
/users index страница, для отображения списка всех пользователей
/users/1 show страница показывающая пользователя с id 1
/users/new new страница для создания нового пользователя
/users/1/edit edit страница для редактирования пользователя с id 1

Но у меня это дело не взлетело, показав вместо ожидаемых страниц, страницу с ошибкой.

Дело оказалось в том, что сгенерированый код конфликтует с кодом в файле application.html.erb, который служит шаблоном для размещения информации о наших пользователях. После некоторого поиска в сети, удалось решить проблему изменением параметра application на default

Было:

<!DOCTYPE html>
<html>
<head>
  <title>Blog</title>
  <%= stylesheet_link_tag    'application', media: 'all', 'data-turbolinks-track' => true %>
  <%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
  <%= csrf_meta_tags %>
</head>
<body>

<%= yield %>

</body>
</html>

Стало:

<!DOCTYPE html>
<html>
<head>
  <title>Blog</title>
  <%= stylesheet_link_tag    'default', media: 'all', 'data-turbolinks-track' => true %>
  <%= javascript_include_tag 'default', 'data-turbolinks-track' => true %>
  <%= csrf_meta_tags %>
</head>
<body>

<%= yield %>

</body>
</html>

Результат

В итоге удалось получить искомые страницы по добавлению пользователей, их редактированию и удалению.

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
МК
13 января 2019 г. 20:35
Мария Канева

C++ - Тест 005. Структуры и Классы

  • Результат:91баллов,
  • Очки рейтинга8
МК
13 января 2019 г. 20:32
Мария Канева

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:70баллов,
  • Очки рейтинга1
МК
13 января 2019 г. 20:28
Мария Канева

C++ - Тест 003. Условия и циклы

  • Результат:78баллов,
  • Очки рейтинга2
Последние комментарии
I
16 января 2019 г. 8:06
IscanderChe

Заработало. Забыл model->select(); вписать.
I
16 января 2019 г. 8:02
IscanderChe

Всё равно пусто, хотя строка с данными в базу добавляется.
16 января 2019 г. 7:51
Евгений Легоцкой

потому, что нужно сохранять информацию для всех остальных ролей и столбцов через вызов переопределённого метода. Да к тому же вы ещё и зациклили вызов метода data. QVariant MySqlTableModel:...
I
16 января 2019 г. 7:43
IscanderChe

Сделал вот так. В tableView ничего нет, кроме заголовка. QVariant MySqlTableModel::data(const QModelIndex &index, int role) const{ if (role == Qt::DisplayRole) { QTime ...
Сейчас обсуждают на форуме
15 января 2019 г. 16:53
Михаиллл

Спасибо, заработало.Но выдало обычный текст без форатирования HTML.Придется искать дальше
15 января 2019 г. 12:52
BlinCT

Я же вам выше написал CLion умеет работать с ремоут машинами. И Qt так же собирает.
ПБ
14 января 2019 г. 14:27
Павел Богдевич

Да
m
13 января 2019 г. 16:52
mihamuz

И так может кому будет интересно решил свою проблему следующим путем.Через дизайнер в базовый виджет добавил QQuickWidget (назвал его listProducts)Это соответственно убрал. this->m_qu...
Присоединяйтесь к нам в социальных сетях

Для зарегистрированных пользователей на сайте присутствует минимальное количество рекламы