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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Haml

Haml(HTML abstraction markup language)は、HTML/XHTMLを効率的に記述するためのマークアップ言語および記法です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

解決済

2回答

3895閲覧

別のコントローラのインスタント変数をビューに参照したい

keisuke.F

総合スコア19

Haml

Haml(HTML abstraction markup language)は、HTML/XHTMLを効率的に記述するためのマークアップ言語および記法です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

0クリップ

投稿2020/08/26 13:53

編集2020/08/26 16:46

お世話になっております。

現在、画像の投稿アプリケーションを作成しています。

#解決したい事
ユーザーマイページで、投稿した画像を一覧表示させたい。

#仮説
tweetsコントローラのインスタンス変数をusers/show.html.hamlで用いようとしているから

#実装した事
usersコントローラのshowアクションに @images = current_user.image
を付与したら

undefined method `image'

のエラーが出た。

#以上からわからない事
アソシエーションを組んでいるのに、なぜ別テーブルのカラムをコントローラに記述できないのか。

下記がコードです。
tweets.controller.rb

class TweetsController < ApplicationController before_action :set_tweet, only: [:edit, :show] def index @tweets = Tweet.all.order(created_at: :desc).includes(:user) end def new @tweet = Tweet.new end def create Tweet.create(tweet_params) end def destroy tweet = Tweet.find(params[:id]) tweet.destroy end def edit end def update tweet = Tweet.find(params[:id]) tweet.update(tweet_params) end def show end private def tweet_params params.require(:tweet).permit(:name, :image, :text).merge(user_id: current_user.id) end def set_tweet @tweet = Tweet.find(params[:id]) end end

users.controller.rb

class UsersController < ApplicationController def show @nickname = current_user.nickname @images = current_user.image end end

tweet.rb

class Tweet < ApplicationRecord validates :image, presence: true mount_uploader :image, ImageUploader belongs_to :user end

user.rb

class User < ApplicationRecord # Include default devise modules. Others available are: # :confirmable, :lockable, :timeoutable, :trackable and :omniauthable devise :database_authenticatable, :registerable, :recoverable, :rememberable, :validatable validates :email, presence: true, format: { with: /\A[\w+\-.]+@[a-z\d\-.]+.[a-z]+\z/i } validates :password, presence: true, length: {minimum: 7},format: { with: /\A(?=.*?[a-z])(?=.*?\d)[a-z\d]{7,128}+\z/i, message: "は英字と数字両方を含むパスワードを設定してください" } has_many :tweets end

tweets/show.html.haml

= render "header" .main .contents .h1.contents__head ○○さんの投稿 .contents__item .contents__item--image{style: "background-image: url(#{@tweet.image});"} .info-contents %p= Date.today %p= @tweet.name %p= @tweet.text = link_to 'トップへ戻る', root_path = render "footer"

users/show.html.haml

.tweetsTitle = @user.nickname さんの投稿一覧 .contents .contents__item - @tweets.each do |tweet| .contents__item--image{style: "background-image: url(#{tweet.image});"}

最下部 ↑ users/show.html.hamlのtweet.imageの記述でエラーが出ています。

単純な問題かもしれないですが、ご教授よろしくお願い致します。

#追記
問題のusers.controller.rbに記述していた

@images = current_user.tweets.imageを

image以外のカラムのnameカラムに変更してみました。

@images = current_user.tweets.name

そうしたらエラーが解決しました。
each文の@tweetの定義エラー等が出たので、
現在のusers.controller.rbはこちらになります。

class UsersController < ApplicationController def show @nickname = current_user.nickname @images = current_user.tweets.image @tweets = Tweet.all end end

やはり、imageにするとエラーが出ます。
エラー文です。

NoMethodError in UsersController#show undefined method `image' for #<Tweet::ActiveRecord_Associations_CollectionProxy:0x00007f35acdd8248>

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

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

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

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

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

guest

回答2

0

ベストアンサー

@images = current_user.tweets.image
これがエラーになるのはcurrent_user.tweets が Tweetのインスタンスではなく、その集合体だからです。Tweetには imageがありますが集合体にはないです。

users_controller の show で @tweets = Tweet.all としてviewで
@tweets.each do |tweet| とやるとcurrent_user以外の全ての人のtweetが一覧されてしまいます。
やるなら @tweets = current_user.tweets です。

最下部 ↑ users/show.html.hamlのtweet.imageの記述でエラーが出ています。

これcurrentエラーメッセージを載せてほしいな、、、
ここはどういうhtmlにしたいのでしょう。
.contents__item- ここは <div class="contents__item-">...</div>にしたいのだな、とはわかりますがそのあとの-image{style: "background-image: url(#{tweet.image});"}が????

なお、tweet.image は画像のURLを得たいのだと思いますが、でしたらtweet.image.url ではないかと思います。

投稿2020/08/26 23:33

winterboum

総合スコア23567

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

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

keisuke.F

2020/08/27 09:57

指示通りに実装したところ、エラーが出ずに反映されました。 しかしながら、 ビューに /uploads/tweet/image/11/BB38ACA4-FFB4-4FFB-BC38-6CD144E1BB97.JPG /uploads/tweet/image/12/IMG_0533.jpg と、画像のurlそのものが表示されてしまいます。 これcurrentエラーメッセージを載せてほしいな、、、に関しては、私の記述ミスで出た”NoMethodError in Users#show”のエラーです。 そちらは、書き方のミスで解決済みです。 ご指示の通り、 -image{style: "background-image: url(#{tweet.image});"} の箇所を、 tweet.image.url に変更しました。
keisuke.F

2020/08/27 10:06

image_tagにしたところ、解決できました!! ありがとうございました!
guest

0

@images = current_user.imageに違和感あります

current_user.tweets.image
でしょうか

current_user.tweet.imageかもしれません

いずれにしても

rails c

コンソールから
同様のインスタンスを作成し、検証してみるのが一番質問者様の理解につながると思います

# 追記

current_user.tweets.image
でいいんだと思うんですが、current_user.tweetsが複数あるために

Tweet::ActiveRecord_Associations_CollectionProxy:0x00007f35b61633c8

エラーとなっているものと思われます

投稿2020/08/26 14:08

編集2020/08/26 16:10
naokit-dev

総合スコア424

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

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

keisuke.F

2020/08/26 14:56 編集

ご回答ありがとうございます。 @images = current_user.imagesとすると、 undefined method `images' for #<User:0x00007f35ac9d22e8>のエラーが出ます。 imagesが定義されていない様ですが、imagesカラムではなく、imageカラムだからだと仮説を立てました。 User modelにhas_many :imagesに関しては、今回は、imagesテーブルは作成しておらず、tweetsテーブル内にimageカラムを作成しています。
naokit-dev

2020/08/26 15:02

であれば `current_user.tweets.image` でしょうか `current_user.tweet.image`かもしれません
keisuke.F

2020/08/26 15:53

current_user.tweets.imageを入力すると、 undefined method `image' for #<Tweet::ActiveRecord_Associations_CollectionProxy:0x00007f35b61633c8> というエラー、 current_user.tweet.imageに変えると undefined method `tweet' for #<User:0x00007f35b59e26a8> Did you mean? tweets tweets= という風に出ます...。 tweetsにすると、imageが定義されていないと言うエラーがですので、tweetsまでは正解で、imageに問題があるのでしょうか? 間違いなくtweetsテーブルのカラムはimageなのですが...。
naokit-dev

2020/08/26 16:09

当初 `current_user.image` とされていましたがTweetモデルのカラムということですのでtweet:image= 1:1ですよね?
keisuke.F

2020/08/26 16:41 編集

imageはテーブルで用意しておらず、tweetテーブルのカラムです。 tweetsとusersのアソシエーションも組んであります。 上記に進展を追記しました。 ご確認をお願いします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問