1

mongoidを使用していて、プレーンなスキャフォールドを生成した後、コードを追加しませんでした。
ポートフォリオインデックスビューページにカテゴリのリストをレンダリングしたい
ので、部分的にレンダリングしました。しかし、以下のようなエラーが発生しました。

NoMethodError in Portfs#index

Showing /Users/suri/Dev/action2/app/views/cats/_list.html.erb where line #1 raised:

undefined method `each' for nil:NilClass
Extracted source (around line #1):

1: <% @cats.each do |cat| %>
2:  <li><%= cat.name %></li>
3: <% end %>

view / portf / index.html.erb

<div class="row">
  <div class="span9">
    <div class="row">
        <ul class="thumbnails">
        <% @portfs.each do |portf| %>
            <li class="span3"style="border:1px solid black;">
            <div class="thumbnail">
                <% portf.images.each do |image| %>
                    <%= image_tag image.file.url(:small) %>
                <% end %>
                <div class="caption">
                <h3><%= link_to (truncate portf.title, :length =>10), portf %></h3>
                <p><%= truncate portf.decs, :length => 30 %></p>
                <p><%= link_to 'Edit', edit_portf_path(portf) %>
                <%= link_to 'Destroy', portf, method: :delete, data: { confirm: 'Are you sure?' } %></p>
                </div>
            </div>
            </li>
        <% end %>
        </ul>
  </div>
  </div>

    <div class="span3">
        <div class="modal fade" id="portf_modal">
            <div class="modal-header">
                <a class="close" data-dismiss="modal">&times;</a>
                <h3>Welcom to <%= image_tag 'logo.png', :height => 12 %></h3>
            </div>
            <div class="modal-body">
                <%= form_for :portf, :html => { :multipart => true } do |f| %>
                <div class="field">
                <%= f.label :title %><br />
                <%= f.text_field :title %>
                </div>

                <%= f.label :Category %><br />
                <%= collection_select(:portf, :category, Cat.all, :name, :name) %>

                <div class="field">
                <%= f.label :decs %><br />
                <%= f.text_area :decs, :class => 'span5', :rows => 10 %>
                </div>
            </div>
            <div class="modal-footer">
                <%= f.submit '올리기', :class => 'btn btn-primary'  %>
                <a href="#" class="btn" data-dismiss="modal">닫기</a>
                <% end %>
            </div>
        </div>

        <form class="form-search">
            <div class="input-append">
            <input type="text" class="span2 search-query">
            <button type="submit" class="btn">Search</button>
            </div>
        </form>

        <p>category</p>
        <% render 'cats/list', :action => "index", :controller => "cats" %>


        <a href="#portf_modal" data-toggle="modal" class="btn btn-primary">포트폴리오 올리기&lt;/a>
    </div>
</div>

view / cats / _list.html.erb

<% @cats.each do |cat| %>
    <li><%= cat.name %></li>
<% end %>
4

2 に答える 2

0

ビューでのパーシャルレンダリングとコントローラーコンテキストでのレンダリングの違いを誤解していると思います。両方のメソッドの名前が同じであるのは残念ですが、ユースケースはまったく異なります。index.html.erbテンプレートの下部で行っているように、ビューでレンダリングする場合、通常は部分的にレンダリングします。パーシャルは、アイテムのコレクションを表示するために使用できるHTMLスニペットのようなものです。あなたの場合、コレクションを@catsコントローラーのインスタンス変数に格納してから、ビューでパーシャルをレンダリングする必要があります。

コントローラ内:

@cats = Cat.all # (or any other collection of cats)

あなたの見解では:

<%= render :partial => 'cats/list' %>
于 2012-09-02T04:07:52.913 に答える
0

@cats は、MVC アーキテクチャに従ってコントローラーからビューに渡されるインスタンス変数です。何かのようなもの

def index
 @cats = Cat.all
end

あなたの view/portf/index.html.erb (パーシャルを呼び出している最後のクロックだけを保持します)

違う

<p>category</p>
        <% render 'cats/list', :action => "index", :controller => "cats" %>

<p>category</p>
        <%= render :partial => "list", :collection => @cats %>

パーシャルを修正する

view/cats/_list.html.erb (ローカルをコレクションとして渡したので、@cats ループを繰り返していません)

<li><%= cat.name %></li>
于 2012-09-02T06:38:48.220 に答える