9

我有一个搜索表单,有很多选项,提交到带有获取请求的路线。网址是这样的:

http://localhost:3000/restaurants/search?utf8=%E2%9C%93&city=&cuisine=&number_of_people=&query=hello

有更多的参数。我想让它更干净,比如删除所有空白的参数。

像这样:(基本上删除所有空白的参数)

http://localhost:3000/restaurants/search?query=hello

这个怎么做?

一种方法可以使用

CGI::parse("foo=bar&bar=foo&hello=hi")

给你

{"foo"=>["bar"], "hello"=>["hi"], "bar"=>["foo"]}

首先在中间动作和中间动作中重定向用户,检查哪些参数为空白并删除它们,然后最终将他重定向到实际的搜索动作。但这听起来很蹩脚的事情。我怎样才能以更好的方式做到这一点?

4

4 回答 4

3

在您的控制器方法中,调用remove_empty_query_params

然后作为私有方法:

  def remove_empty_query_params
    # Rewrites /projects?q=&status=failing to /projects?status=failing
    require 'addressable/uri'
    original = request.original_url
    parsed = Addressable::URI.parse(original)
    return unless parsed.query_values.present?
    queries_with_values = parsed.query_values.reject { |_k, v| v.blank? }
    if queries_with_values.blank?
      parsed.omit!(:query)
    else parsed.query_values = queries_with_values
    end
    redirect_to parsed.to_s unless parsed.to_s == original
  end
于 2016-05-05T03:09:42.773 回答
2

我的解决方案是禁用空白输入并选择:

$('form').submit (e) ->
  $(@).find('select,input').map( (i, e) -> e.disabled = !$(e).val() )

关于删除utf8我发现了这个。所以我最好继续发送它。

在使用 redirect_to 时,在服务器上执行所有这些操作会导致额外的请求,因此我更喜欢使用客户端代码。

于 2015-07-04T22:07:46.833 回答
1

只是用普通的红宝石......

require 'uri'
a = "http://localhost:8080/path/search?foo=&bar=&baz=2&bat=thing"
u = URI.parse(a)
params = u.query.split("&").select {|param| param =~ /=./}.join("&")
# Returns "baz=2&bat=thing" 
于 2012-06-19T14:00:35.723 回答
0

我建议,如果只是看普通的旧红宝石,一个简单的 gsub 可能就足够了:

url.gsub(/[^\?&=]+=(?:&|$)/, '')

注意:这可能会在末尾留下一个&符号,可以用

url.chomp('&')
于 2012-06-19T16:11:39.293 回答