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 %>

查看/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>

查看/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 回答