定制过滤器

过滤器允许你将函数应用于变量。此函数可能需要 01 个参数。这是语法:

{{ variable|filter_name }} 
{{ variable|filter_name:argument }}

过滤器可以链接,因此这是完全有效的:

{{ variable|filter_name:argument|another_filter }}

如果转换为 python,上面的行会给出这样的结果:

print(another_filter(filter_name(variable, argument)))

在这个例子中,我们将编写一个适用于 Model(实例或类)或 QuerySet 的自定义过滤器 verbose_name。如果参数设置为 True,它将返回模型的详细名称或其详细名称复数。

@register.filter
def verbose_name(model, plural=False):
    """Return the verbose name of a model.
    `model` can be either:
      - a Model class
      - a Model instance
      - a QuerySet
      - any object refering to a model through a `model` attribute.

    Usage:
      - Get the verbose name of an object
          {{ object|verbose_name }}
      - Get the plural verbose name of an object from a QuerySet
          {{ objects_list|verbose_name:True }}
    """
    if not hasattr(model, '_meta'):
        # handle the case of a QuerySet (among others)
        model = model.model
    opts = model._meta
    if plural:
        return opts.verbose_name_plural
    else:
        return opts.verbose_name