5

嗨,我只需要打印出 active 为 == 0 的候选人,这是我在视图中的代码。

如果 active 是 yes 或 no,我可以打印。但是在每个 do 循环中,我只想打印活动的候选人。

那么如何将条件添加到我的每个 do 循环中,谢谢。
  <% @candidates.each do |candidate| %>
    <div id="candidateper">
  <div class="avatth" ><div class="avat_min">
    <% if candidate.avatar.present? %>
       <%= link_to (image_tag candidate.avatar.url(:thumb)), (candidate_path(candidate))  %>
     <% else %>
     <%= link_to (image_tag ("espanol/playersample.png")), (candidate_path(candidate))  %>

     <% end %>
  </div></div>



      <div class="nameth"><%= candidate.name %></div>
      <div class="activeth"><%= candidate.active ? t('generales.yess') : t('generales.noo') %></div>
      <div class="generalth">
        <% if candidate.user.purchased_at.present? %>
          <%= candidate.user.purchase_defeated? ? t('generales.defeated') : t('generales.active') %>
        <% else %>
          <%=  t('generales.noo') %>
        <% end %>
      </div>

      <div class="actionsth"><%= link_to t('generales.show'), candidate_path(candidate) %>
      <% if current_user.user_type == 'admin' %>
      <%= link_to t('generales.delete'), candidate_path(candidate), method: :delete, data: { confirm: t('generales.delete_candidate_confirm') } %>
     <% end %>
    </div>
    </div>
  <% end %>

</div>
  <% end %>

我试过这个

我所有的想法都没有运气语法错误:P

4

1 回答 1

13

如果candidate.active实际上是一个布尔值,那么你可以说:

<% @candidates.reject(&:active).each do |candidate| %>
    ...
<% end %>

如果@candidates实际上是一个,ActiveRecord::Relation那么您可能会说:

<% @candidates.where(:active => false).each do |candidate| %>
    ...
<% end %>

避免在你不想要的时候从数据库中拉出一堆东西。

如果active实际上是一个数字(在数据库内部和数据库外部),那么您可以说:

<% @candidates.select(&:zero?).each do |candidate| %>
    ...
<% end %>

或者

<% @candidates.where(:active => 0).each do |candidate| %>
    ...
<% end %>
于 2013-09-23T01:23:17.487 回答