昨天用自己的方法实现了排序,所以想“得寸进尺”实现查询。不过还是找了一个资料才成功=。=|
- routes修改一下:
resources :products do
collection do
get 'search'
end
end
- views中增加:
<%= form_tag "/products/search", method: "get" do %>
<%= label_tag :s_price, "Price" %>
<%= text_field_tag :s_price %>
<%= submit_tag "Search" %>
<% end %>
- 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
感觉勉强可以。。。以后学到新的东西再来更新。