1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Rails7でHelloWorld

Last updated at Posted at 2022-07-30

前提

  • Rails(前回の記事で手順を記載しています)

  • DBに登録されたデータをControllerで取得し、Viewで表示するシンプルな内容になっています

Controllerを作成

  • rails g controller users indexでUsersControllerを作成
    • ApplicationControllerを継承しています
  • Hello, Worldをブラウザに表示させます
    • renderの行を追記します
app/controller/users_controller.rb
class UsersController < ApplicationController
  def index
    render plain: 'Hello, World'
  end
end

画面を表示

  • rails sでサーバ起動
    • URLの末尾に/users/indexを指定します

ルーティングの変更

  • URLとactionを紐付ける設定

config/routes.rbを以下の通り修正

- get 'users/index'
+ get 'users', to: "users#index"
  • 画面を表示
    • URLの末尾を/usersに修正
    • indexの指定が不要になりました

Viewで表示

  • MVCモデルに従い、Controllerから表示せずViewで表示するように修正します

viewファイルを修正

  • app/views/users/index.html.erbを修正
    • controller名/action名.html.erbのルールになっています
    • 初期の記述は削除しています
app/views/users/index.html.erb
<p>Hello, View!</p>
  • controllerを修正
    • renderの行を削除しました
app/controller/users_controller.rb
class UsersController < ApplicationController
  def index
  end
end
  • 画面を表示
    • viewに記述したHello, View!が表示されました

ControllerからViewに値を渡して表示する

app/controller/users_controller.rb
class UsersController < ApplicationController
  def index
    @message = "Hello, Controlller!"
  end
end
app/views/users/index.html.erb
<p><%= @message %></p>
  • Controllerでセットした@messageの内容ををViewで表示しました

Modleを作成

  • rails g model User name:string age:integerでUserModelを作成
    • 文字列型のname,数値型のageで構成されるモデル
  • migrationファイルが自動生成されています
    • ちなみに会社ではRidgepoleを採択しています、追々やります
  • migrationを実行します
    • rails db:migrateでマイグレーション実行
    • DDLが実行されテーブルができます
    • rails dbconsoleでSQL操作ができるので、テーブル定義を確認しました
    • この後tanakaも作成しました

データベースの値を画面に表示します

  • データを登録します(登録できれば下記方法ではなく、前述したdbconsoleからInsertするでも問題ないです)
  • Contollerでusersテーブルのデータ全件を取得します
app/controller/users_controller.rb
class UsersController < ApplicationController
  def index
    @message = "Hello, Controlller!"
    @users = User.all
  end
end
  • Viewで取得したusersのデータ全件を繰り返し出力します
app/views/users/index.html.erb
<p><%= @message %></p>
<ul>
  <% @users.each do |user| %>
    <li>
      ID:<%= user.id %>, Name:<%= user.name %>, Age:<%= user.age %>
    </li>
  <% end %>
</ul>
  • 画面にusersテーブルのデータが表示されました

最後に

  • MVCモデルをとりあえず作りたかったため、とてもシンプルな構成になりました
  • モデルを増やして、関連あたりも勉強していきたいですね
  • やったことを順に手順化しただけなのでわかりにくい可能性あります、ご了承くださいませ
1
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?