我有一个表格显示一些不同的数据属性,我遵循railscast#228使列可排序。几乎所有的工作除了一个名为“groups”的标题,当我点击链接我的方向箭头中断,它回复到原始标题(为了清楚起见,我会发布截图)。我有一个助手,一个控制器和一个呈现问题代码功能的视图,现在我将显示相应的代码,并尽我所能来描述为了帮助我而需要知道的一切。这是我的观点。您可以在@people块中看到<td><%= person.groups.order(:id).pluck(:name).to_sentence %></td>
是问题所在。Glyphicon箭头帮助排序列
<table class="table table-striped">
<thead>
<tr>
<th><%= sortable 'phone_number', 'Phone Number'%></th>
<th><%= sortable 'subscribed', 'Subscribed'%></th>
<th><%= sortable 'city' %></th>
<th><%= sortable 'state' %></th>
<th><%= sortable 'zip' %></th>
<th><%= sortable 'country' %></th>
<th><%= sortable 'groups' %></th>
<th><%= sortable 'created_at', "Joined" %></th>
</tr>
</thead>
<% @people.each do |person| %>
<tr>
<td><%= person.phone_number %></td>
<td><%= person.subscribed? ? "Yes" : "No" %></td>
<td><%= person.city %></td>
<td><%= person.state %></td>
<td><%= person.zip %></td>
<td><%= person.country %></td>
<td><%= person.groups.order(:id).pluck(:name).to_sentence %></td>
<td><%= time_ago_in_words person.created_at %> ago</td>
</tr>
<% end %>
这里是排序的辅助方法
def sortable(column, title = nil)
title ||= column.titleize
if column != sort_column
css_class = nil
direction = "asc"
elsif sort_direction == "asc"
css_class = "glyphicon glyphicon-triangle-top"
direction = "desc"
else
css_class = "glyphicon glyphicon-triangle-bottom"
direction = "asc"
end
link_to "#{title} <span class='#{css_class}'></span>".html_safe, sort: column, direction: direction
end
这里是我的控制器
def index
@people = Person.order(sort_column => sort_direction)
@groups = Group.all
end
这些都是私人
def sort_column
Person.column_names.include?(params[:sort]) ? params[:sort] : "phone_number"
end
def sort_direction
%w(asc desc).include?(params[:direction]) ? params[:direction] : "asc"
end
这里是截图的排序方法,这是结果点击“群组”标题。正如你所看到的,它会回复到电话号码。 *注 - 每个其他标题都会正确排序并显示排序箭头。
是的,我想按组名排序 – Bitwise
@ CameronBass如何在该列中有多个组时按组名称排序?如果有一个带有“访客”的专栏,一个带有“访客,员工”和一个带有“志愿者,跳舞”的专栏 - 您喜欢的订单是什么,为什么? – spickermann
我只是按字母顺序思考,就好像只有'员工'中有一个人,而'志愿者'中有一个人,用户可以按这种方式排序。诚然,它不会很有用,但它会保持整个页面的连续性。 – Bitwise