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

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

ただいまの
回答率

88.77%

rails tutorial 13章 'nil' is not an ActiveModel-compatible object エラーを解決したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 238

ketyan

score 22

現状

現在rails tutorial13章マイクロポストの描画を勉強中です。

ユーザーのmicropostを一覧で表示させようとしたところ、タイトルの
'nil' is not an ActiveModel-compatible object. It must implement :to_partial_path.
というエラーがサーバーに表示されました。

エラーコード

エラーはapp/views/users/show.html.erbファイルの15行目、
<%= render @microposts %>の行で起きているようでした。

<% provide(:title, @user.name) %>
<div class="row">
  <aside class="col-md-4">
    <section class="user_info">
      <h1>
        <%= gravatar_for @user %>
        <%= @user.name %>
      </h1>
    </section>
  </aside>
  <div class="col-md-8">
    <% if @user.microposts.any? %>
      <h3>Microposts (<%= @user.microposts.count %>)</h3>
      <ol class="microposts">
        <%= render @microposts %>
      </ol>
      <%= will_paginate @microposts %>
    <% end %>
  </div>
</div>


@micropostはusers_controller内のshowアクションで定義しています。

  def show
    @user = User.find(params[:id])
    @microposts = @user.microposts.paginate(page: params[:page])
  end

試したこと

ネットで似た状況の質問を見ていると、@micropostsに値が渡されていないことが
原因だった場合が多く、また部分テンプレートへのパスを直接指定するために
show.html.erbをunlessを使い以下のように書き換えました。

<% provide(:title, @user.name) %>
~略~
  <ol class="microposts">
    <% unless @microposts.blank? %>
     <%= render partial: "microposts/micropost", locals: { microposts: micropost.content }%>
    <%end%>
  </ol>
    <% unless @microposts.blank? %>
      <%= will_paginate @microposts %>
    <%end%>
  <% end %>
  </div>
</div>

するとイメージ説明

このようにユーザー名、ユーザーのマイクロポスト数は表示されており、変数に値自体は入っているように思えます。

サーバーのログを載せておきます。

app/views/users/show.html.erb:15:in `_app_views_users_show_html_erb__2336219684752338369_70290005700780'
Started GET "/users/1" for 106.172.115.46 at 2019-10-27 12:51:29 +0000
Cannot render console from 106.172.115.46! Allowed networks: 127.0.0.1, 127.0.0.0/127.255.255.255, ::1
Processing by UsersController#show as HTML
  Parameters: {"id"=>"1"}
  User Load (0.2ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = ? LIMIT ?  [["id", 1], ["LIMIT", 1]]
  Rendering users/show.html.erb within layouts/application
  Micropost Exists (0.1ms)  SELECT  1 AS one FROM "microposts" WHERE "microposts"."user_id" = ? LIMIT ?  [["user_id", 1], ["LIMIT", 1]]
   (0.1ms)  SELECT COUNT(*) FROM "microposts" WHERE "microposts"."user_id" = ?  [["user_id", 1]]
  Rendered users/show.html.erb within layouts/application (3.2ms)
  Rendered layouts/_shim.html.erb (0.3ms)
  User Load (0.2ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = ? LIMIT ?  [["id", 1], ["LIMIT", 1]]
  Rendered layouts/_header.html.erb (1.9ms)
  Rendered layouts/_footer.html.erb (0.3ms)
Completed 200 OK in 50ms (Views: 47.2ms | ActiveRecord: 0.6ms)

このような状況ですが、どこに原因があると考えられるでしょうか。
ご回答、よろしくお願いいたします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

google翻訳
'nil'はActiveModel互換オブジェクトではありません

ということなので、エラーが出たあたりの変数がnilになってないかチェックしてみては

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/10/28 10:42

    Y_waiwaiさん、ご回答ありがとうございます。

    恥ずかしながら、@micropostsを定義したメソッドよりも後に、同変数を定義するメソッドが残っていたために起きていたエラーでした。

    キャンセル

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

  • ただいまの回答率 88.77%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る