ruby on rails 一步步开始(2)分页和简单查询

本文介绍如何在Ruby on Rails应用中使用Will Paginate插件实现分页,并结合简单查询功能。通过安装gem并配置控制器和视图,可以有效地根据标题进行搜索并分页显示结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用 will_paginate 进行分页和简单查询

在命令行下使用 gem install will_paginate 命令,出现下面结果安装成功

打开 books_controller.rb (你自己的控制器)

注释掉查找全部的方法,使用下面的方法,已经集成根据title进行查询

Ruby代码 复制代码
  1. #@books=Book.all
  2. @books=Book.paginate:page=>params[:page],
  3. :per_page=>2,
  4. :conditions=>["titlelike?","%#{params[:search]}%"]
  5. respond_todo|format|
  6. format.html#index.html.erb
  7. format.xml{render:xml=>@books}
  8. end
  9. end
#@books = Book.all
@books = Book.paginate :page => params[:page],   
                               :per_page => 2, 
                               :conditions => ["title like ?", "%#{params[:search]}%"] 
    respond_to do |format|
      format.html # index.html.erb
      format.xml  { render :xml => @books }
    end
  end

打开对应的 books_controller.rb 视图页面 index.html.erb

添加查询功能

Html代码 复制代码
  1. <%form_tagbooks_path,:method=>'get'do%>
  2. <p>
  3. <%=text_field_tag:search,params[:search]%>
  4. <%=submit_tag"Search",:name=>nil%>
  5. </p>
  6. <%end%>
<% form_tag books_path, :method => 'get' do %> 
<p> 
    <%= text_field_tag :search, params[:search] %> 
    <%= submit_tag "Search", :name => nil %> 
</p> 
<% end %> 

及分页功能

Html代码 复制代码
  1. <div>
  2. <div>
  3. <%=page_entries_info@books%>
  4. </div>
  5. <%=will_paginate@books,:container=>false%>
  6. </div>
 <div>
      <div >
        <%= page_entries_info @books %>
      </div>
      <%= will_paginate @books, :container => false %>
    </div>

打开环境文件 environment.rb 在end后添加

Ruby代码 复制代码
  1. require"will_paginate"
require "will_paginate"

运行效果如下


本文转自:http://95700900.javaeye.com/blog/573308

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值