質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

633閲覧

Progateでわからないこと

tetsuya7724

総合スコア67

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/06/02 05:30

前提・実現したいこと

Progateで勉強しています。
学習コースⅦ ユーザー画像を表示しようで、imgタグをつけるとありますが、user.index.htmlでは <img src="<%= "/user_images/#{user.image_name}" %>" >。
user.show.htmlでは<img src="<%= "/user_images/#{@user.image_name}" %>" >と@がついているのとついていないのがあります。

一応これでらしいのですが、同じ画像を表示しているはずなのになぜ@がつくのとつかないのがあるのでしょうか。
教えていただけるとありがたいです。

該当のソースコード

html

1#show.html.erb 2 3<div class="main user-show"> 4 <div class="container"> 5 <div class="user"> 6 <!-- <img>タグを用いて、プロフィール画像を表示してください --> 7 <img src="<%= "/user_images/#{@user.image_name}" %>" > 8 <h2><%= @user.name %></h2> 9 <p><%= @user.email %></p> 10 <%= link_to("編集", "/users/#{@user.id}/edit") %> 11 </div> 12 </div> 13</div>

html

1index.html.erb 2 3<div class="main users-index"> 4 <div class="container"> 5 <h1 class="users-heading">ユーザー一覧</h1> 6 <% @users.each do |user| %> 7 <div class="users-index-item"> 8 <!-- 指定されたHTMLを貼り付けてください --> 9 <div class="user-left"> 10 <!-- <img>タグを用いて、プロフィール画像を表示してください--> 11 <img src="<%= "/user_images/#{user.image_name}" %>" > 12 </div> 13 <div class="user-right"> 14 <%= link_to(user.name, "/users/#{user.id}") %> 15 </div> 16 </div> 17 <% end %> 18 </div> 19</div>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

見ている変数が違うからだと思いますよ。

index.html.erbでは

<% @users.each do |user| %>

として@usersの中身を取り出してuserと名付けて、その変数の名前を使って画像を取得しています。

show.html.erbにはそのような宣言が見当たらないので、controllerからクラス変数として@userを参照しているかと

投稿2020/06/02 05:38

編集2020/06/02 05:40
unio

総合スコア12

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tetsuya7724

2020/06/02 05:45

そういうことですか。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問