在Jinja2模板引擎

时间:2017-11-21 10:40:19

标签: django-forms jinja2 django-widget-tweaks

我正在使用django v1.11.7和Jinja2 v2.10作为模板引擎。

在我的网站中,我希望使用bootstrap渲染表单。我发现django-widget-tweaks可以用于此集成。

此软件包不适用于Jinja模板,因为它需要将自定义标记集加载到Jinja环境中。加载标记集可能很复杂,因为我可能需要编写扩展名。

有没有一种简单的方法可以让django-widget-tweaks与Jinja一起使用?还是有另一种方法将boostrap与Jinja整合在一起吗?

1 个答案:

答案 0 :(得分:1)

有点晚了,但是也许可以帮上忙。

我所做的是导入要使用的函数,并在jinja模板中对其进行了调用:

app_root.jinja2.py

from jinja2 import Environment
from jinja2 import contextfunction

from widget_tweaks.templatetags.widget_tweaks import render_field


def environment(**options):
    env = Environment(**options)
    env.globals.update({
        'render_field': render_field,
    })
    return env

在模板中

{% set class = class + "my-html-class" %}
{{ render_field(field, class) }}

编辑:拥有一点Jinja和模板标签经验的人都知道这是行不通的。为了满足当前的需求,我在jinja配置中定义了以下两个函数,稍后将评估我的需求。

def set_attr(bound_field, attr, value):
    bound_field.field.widget.attrs[attr] = value
    return bound_field

def add_class(bound_field, value):
    try:
        bound_field.field.widget.attrs['class'] += value
    except KeyError:
        bound_field.field.widget.attrs['class'] = value
    return bound_field

编辑2 其他有用的链接:https://github.com/niwinz/django-jinja/issues/140

要使此解决方案有效,我必须进行以下更改: jinja2.py

from jinja2 import Environment
from widget_tweaks.templatetags.widget_tweaks import add_class
from widget_tweaks.templatetags.widget_tweaks import set_attr


def environment(**options):
    env = Environment(**options)
    env.filters['set_attr'] = set_attr
    env.filters['add_class'] = add_class
    return env

template.html

{{ form.field |set_attr('attr:val') }}
{{ form.field |add_class('my_class') }}