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

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

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

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

Q&A

1回答

1429閲覧

railsで作成中の画像にリンクを貼り付けたい

TaigaYoshizaki

総合スコア12

Ruby on Rails 5

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

0グッド

0クリップ

投稿2019/07/20 08:00

railsで作成中の画像にリンクを貼り付けたい

現在、railsで画像にリンクを張り付けshow(一覧ページ)に飛ばすリンクを作成中なのですが、以下のエラーが出ています。

発生している問題・エラーメッセージ

NoMethodError in Books#show
Showing /vagrant/bookers-lv2/app/views/books/show.html.erb where line #44 raised:

undefined method `user_id' for nil:NilClass

該当のソースコード

<table class="table table-book" style="width: 70%;"> <thead> <h2>Book detail</h2> </thead> <tbody>
<tr> <% @books.each do |book| %> <td><%= link_to user_path(book.user.user_id) do %> <%= attachment_image_tag @user, :profile_image %> <%= book.user.name %> <% end %></td> <td><%= book.title %></td> <td><%= book.body %></td> <% end %> </tr> </tbody> </table>

以下はbookのコントローラーです。

class BooksController < ApplicationController
def index
@user = User.find(current_user.id)
@users = User.all
@books = Book.all
@book = Book.new
end

def show
@user = User.find(current_user.id)
@users = User.all
@books = Book.all
@newbook = Book.new
end

def create
book = Book.new(book_params)
book.save
flash[:success]='You have created book successfully.'
redirect_to users_detail_path(book.id)
end

def edit
@book = Book.find(params[:id])
end

def update
book = Book.new(book_params)
book.save
flash[:success]='You have updated book successfully.'
redirect_to books_path(book.id)
end

def destroy
book= Book.find(params[:id])
book.destroy
redirect_to books_path
end

private
def book_params
params.require(:book).permit(:title, :body)
end

end

試したこと

このファイルはuserとbookの2つのモデルがあり、1対多の関係です。link_toの指定先はshowページでbookのモデルに結びついたuserのidを指定したのですが、エラーが発生しました。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

bamboo-nova

2019/07/20 08:03

すみません、Markdown形式でプログラムを載せていただけないでしょうか? ```と```の間に文章を挿入していただけるだけでも大分読みやすくなります。
bamboo-nova

2019/07/20 08:45

すみません、元の質問をMarkdown形式で修正してください。あと、ビューとコントローラで別々に分けてください
guest

回答1

0

<% @books.each do |book| %> <td><%= link_to user_path(book.user.user_id) do %> <%= attachment_image_tag @user, :profile_image %>

ここの部分ですが、userにはuser_idではなくidではないでしょうか。(質問者さんがどのような挙動であってほしいか書かれていなかったので推測ですが...)

投稿2019/07/20 08:08

bamboo-nova

総合スコア1408

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

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

TaigaYoshizaki

2019/07/20 08:28 編集

まだプログラミングを初めて2週間なので、説明が曖昧ですみません。マークダウン記法ももう少し勉強したいと思います。bamboo-nova様のご指摘どうり実装しましたが今度は、以下のエラーが出ました。 ``` NoMethodError in Books#show Showing /vagrant/bookers-lv2/app/views/books/show.html.erb where line #44 raised: undefined method `id' for nil:NilClass ``` ここのページは各ユーザーのプロフィール画像が表示され、画像をクリックすると各ユーザーの詳細ページに移動する機能を実装したいです。 ``` ActiveRecord::Schema.define(version: 2019_07_18_045038) do create_table "books", force: :cascade do |t| t.string "title" t.text "body" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.integer "user_id" end create_table "post_images", force: :cascade do |t| t.integer "user_id" t.datetime "created_at", null: false t.datetime "updated_at", null: false end create_table "users", force: :cascade do |t| t.string "email", default: "", null: false t.string "encrypted_password", default: "", null: false t.string "reset_password_token" t.datetime "reset_password_sent_at" t.datetime "remember_created_at" t.integer "sign_in_count", default: 0, null: false t.datetime "current_sign_in_at" t.datetime "last_sign_in_at" t.string "current_sign_in_ip" t.string "last_sign_in_ip" t.string "name" t.text "introduction" t.integer "profile_image_id" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.index ["email"], name: "index_users_on_email", unique: true t.index ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true end end ``` 以上のuserテーブルのuser_idを引っ張ってきたいのですがエラーが出ます。
bamboo-nova

2019/07/20 09:06

すみません、<%= link_to user_path(book.user) do %>としてみて頂けませんか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問