我正在研究Rails 3.2 ruby 1.9.2项目。
我从数据库中获得了一些经典的值(value):
designators = Model.find()
我用(简化的代码)展示了它:
<table class="rwy_modes_table" cellspacing='0'>
<% designators.each do |info_design| %>
<tr id="rwy_mode_<%=info_design.id%>">
<td class="spacer"><%= info_design.try(:designator) %></td>
</tr>
<% end %>
</table>
值例如:3L,3C,3R。 (左为L,右为C,右为4)。
我想要订购的值,例如:3L,3C,3R而不是3C,3L,3R
我不知道如何定义此自定义订单。任何想法 ?
最佳答案
尝试这样的事情:
(app/models/designator.rb)
# determines the sort value for based on my_attribute.
# designators should be in the order 'l', 'c', 'r' - regardless of any preceeding numeral
def sort_val
return 0 if self.my_attribute =~ /l/i
return 1 if self.my_attribute =~ /c/i
return 2 if self.my_attribute =~ /r/i
end
(app/helpers/designators_helper.rb)
def sorted_designators(designators)
designators.sort{|a, b| a.sort_val <=> b.sort_val }
end
您可以在何处对 View 进行排序
(app/views/...)
sorted_designators(designators).each do |design|
或者,您可以将其移至模型文件中的静态方法,以方便在 View 外部进行排序
(app/models/designator.rb)
def self.sorted_designators(designators)
designators.sort{|a, b| a.sort_val <=> b.sort_val }
end
并像这样在您的 Controller 中使用它们
app/controllers...
@designators = Designator.sorted_designators(designators)
注意:这是内存中的排序,因此请注意O(n)db查询,具体取决于您对此对象进行排序/访问的方式
另请参阅:https://stackoverflow.com/a/14282353/811255,以使用Comparable模块(可能是更清洁的解决方案)