ROR学习笔记(37)——查询&查询后的排序(非ajax)

昨天用自己的方法实现了排序,所以想“得寸进尺”实现查询。不过还是找了一个资料才成功=。=|

  1. routes修改一下:
  resources :products do
    collection do
      get 'search'
    end
  end
  1. views中增加:
  <%= form_tag "/products/search", method: "get" do %>
  <%= label_tag :s_price, "Price" %>
  <%= text_field_tag :s_price %>
  <%= submit_tag "Search" %>
  <% end %>
  1. controller中增加:
  def search    
    if params[:s_price] == ""
      redirect_to :back
    else
      query = "price like \'%s\'" % params[:s_price]
      @products = Product.where(query).paginate(page: params[:page], per_page: 12)
      render 'index'
    end    
  end

这样就实现了对价格的查询
但有一个问题:查询完后,点击表头想对查询后的结果进行排序时,又重新查询了一遍所有的products然后再进行排序。
想了很多“招”,最开始是用request.referer来判断如果是从查询结果页面跳转到排序页面,那么就把查询结果页面的url中的查询条件解析出来,查询后再进行排序。“Bingo!",点了一下排序,居然成功了!还以为自己超给力,结果第二次排序的时候,又变成了对所有products的查询了,原因就是:当进行了一次排序后,再进行排序request.referer不是查询页面了, 而是排序页面。所以出错。
OK,再想想有没有其它的方法。
突然之间,我想到了用cookies来存放查询语句,先试一下:所以代码写成了这样:
controller中:

  def index
    @products = Product.all.paginate(page: params[:page], per_page: 12)
    query = "1 = 1"
    cookies[:query] = query
  end
  def sort_by
    query = cookies[:query]
    if @order[:p_by].include?(params[:sort_id])
      order_change(@order, params[:sort_id])
      @products = Product.where(query).order("%s %s" % params[:sort_id].split("_")[1..2])
      @products = @prdutcs.paginate(page: params[:page], per_page: 12)
      respond_to do |format|
        format.html {render 'index'}       
      end
    else
      redirect_to root_path
    end
  end
  def search    
    if params[:s_price] == ""
      redirect_to :back
    else
      query = "price like \'%s\'" % params[:s_price]
      @products = Product.where(query).paginate(page: params[:page], per_page: 12)
      cookies[:query] = query
      render 'index'
    end    
  end

这次果然成功了!!
但又有一个问题,因为通过cookies的话,必然把数据库的列名暴露无遗,而我又想不到其它办法来处理,所以想到把cookies[:query]进行加密,controller中最终代码如下

def index
    @products = Product.all.paginate(page: params[:page], per_page: 12)
    query = "1 = 1"
    cookies[:query] = encode(query)
  end
  def sort_by
    query = decode(cookies[:query])
    if @order[:p_by].include?(params[:sort_id])
      order_change(@order, params[:sort_id])
      @products = Product.where(query).order("%s %s" % params[:sort_id].split("_")[1..2])
      @products = @products.paginate(page: params[:page], per_page: 12)
      respond_to do |format|
        format.html {render 'index'}       
      end
    else
      redirect_to root_path
    end
  end
  def search    
    if params[:s_price] == ""
      redirect_to :back
    else
      query = "price like \'%s\'" % params[:s_price]
      @products = Product.where(query).paginate(page: params[:page], per_page: 12)
      cookies[:query] = encode(query)
      render 'index'
    end    
  end
  private
    def encode(string)
      Base64.encode64(Digest::SHA1.hexdigest("tangxiaoyonghaoshuai") + string)
    end
    def decode(string)
      Base64.decode64(string)[40..-1]
    end

感觉勉强可以。。。以后学到新的东西再来更新。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容