我正在寻找Rails的宝石按字母顺序分页.我希望我能找到结果中找到的第一个字母列表(我的意思是,如果没有以’a’开头的行,我不希望在分页链接上显示’a’).这种宝石已经存在吗?
@H_403_2@提前致谢!
解决方法
这根本不容易创建,例如,如果你有一个发现,可能像:
@all_words = Word.select("words.word")@H_403_2@…返回一个结果集的结果,如这样的单词列表:
["alphabet","boy","day","donkey","ruby","rails","iPad"]@H_403_2@……你可以这样做:
@all_words.collect {|word| word[0,1]}.uniq.sort@H_403_2@会返回:
["a","b","d","r","i"]@H_403_2@.collect {| word | word [0,1]}将每个单词的第一个字母存储到一个新数组中,而uniq过滤掉这些独特的字母,并按字母顺序对这些字母进行排序. @H_403_2@只需将其分配给变量,您就可以在视图中使用它,如下所示:
<ul> <% @first_letters.each do |letter| %> <%= content_tag :li,link_to(letter,words_pagination_url(letter),:title => "Pagination by letter: #{letter}") %> <% end %> </ul>@H_403_2@然后你的控制器动作可以决定如果传入一个paramination中的param怎么办:
def index if params[:letter] @words = Word.by_letter(params[:letter]) else @words = Word.all end end@H_403_2@然后,模型中的范围看起来像:
scope :by_letter,lambda { |letter| { :conditions => ["words.word LIKE ?","#{letter}%"] }}@H_403_2@您的路线需要以下内容:
match "words(/:letter)" => "words#index",:as => words_pagination@H_403_2@我没有完全测试过,但它应该让你走上正确的道路.