2016-07-12 48 views
0

我需要从GET网址中删除参数。我没有找到一个“正确”的方式做到这一点,所以我写了我自己的过滤器是这样的:如何正确删除GET参数

@register.filter(name='url_without_parameter') 
def url_without_parameter(arg1, arg2): 
    """ 
    Removes an argument from the get URL. 
    Use: 
     {{ request|url_without_parameter:'page' }} 

    Args: 
     arg1: request 
     arg2: parameter to remove 
    """ 
    if arg1.GET.getlist(arg2): 
     # get all parameters : 
     full_url = urlparse.urlparse(arg1.get_full_path()) 
     parameters = {} 
     # reconstruct query 
     for key, value in urlparse.parse_qsl(full_url.query): 
      if parameters.get(key, None) is None: 
       parameters[key] = value 
     # remove parameters 
     if parameters.get(arg2) is not None: 
      del parameters[arg2] 
     arg1.META['QUERY_STRING'] = u'&'.join([ 
      u'{}={}'.format(key, value) 
      for key, value in parameters.iteritems()]) 

    return arg1.get_full_path() 

然后我用这样的:

{{ request|url_without_parameter:'page' }} 

和先进的方式是:

href="{{ request|url_without_parameter:'page' }}&page={{ obj.page }}" 

我的问题是,当有没有在URL中的GET其他参数。这会创建一些网址,例如“/test&page=1”,这个网址不好。

所以我不得不写另一个过滤器,使这项工作这样的:

href="{{ request|url_without_parameter:'page' }}{{ request|url_get_separator }}page={{ obj.page }}" 

随着我url_get_separator过滤器。

@register.filter(name='url_get_separator') 
def url_get_separator(arg1): 
    """ 
    Returns '?' or '&' if there are QUERY parameters in the URL 
    Use: 
     {{ request|url_get_separator }} 

    Args: 
     arg1: request 
    """ 
    return u'&' if arg1.META.get('QUERY_STRING', '') else u'?' 

我觉得所有这些都很难看,很难阅读,也很难维护。你知道任何其他更好的方法来简单地替换网址中的GET的值吗?

+1

你可以尝试使用django-url-tools,特别是'overload_params'和'del_params' [模板标签](https://bitbucket.org/monwara/django-url-tools#rst-header-id39) 。另见[这个问题](http://stackoverflow.com/questions/16469224/django-template-tag-to-insert-or-replace-url-parameter)。 – Alasdair

回答

0

我一直都用这个标签的分页链接我的项目,即在保留的一切,但切换页面数的数值超链接,你会发现我垃圾桶_pjax PARAM如果它存在:

@simple_tag 
def query_transform(request, **kwargs): 
    """usages: {% query_transform request page=1 %}""" 
    updated = request.GET.copy() 

    for k, v in kwargs.iteritems(): 
     updated[k] = v 

    # trash any pjax params, we never want to render those 
    try: 
     del updated['_pjax'] 
    except KeyError: 
     pass 

    return updated.urlencode() 

我想也许你想要类似的东西,也许你错过的技巧是在request.GET字典上调用copy,并弄乱了它,而不是URL。