将 django-widget-tweaks 与 Jinja2 模板引擎结合使用

rva*_*aga 5 django-forms jinja2 django-widget-tweaks

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

在我的网站中,我希望使用引导程序呈现表单。我发现django-widget-tweaks可用于此集成。

该包无法与 Jinja 模板一起使用,因为它需要将自定义标签集加载到 Jinja 环境中。加载标签集可能很复杂,因为我可能需要编写扩展。

有没有一种简单的方法可以让 django-widget-tweaks 与 Jinja 一起工作?或者还有其他方法将 boostrap 与 Jinja 集成吗?

Vin*_*tie 4

有点晚了,但也许这会有所帮助。

我所做的是导入我想要使用的函数并在我的 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
Run Code Online (Sandbox Code Playgroud)

在模板中

{% set class = class + "my-html-class" %}
{{ render_field(field, class) }}
Run Code Online (Sandbox Code Playgroud)

编辑:任何有一点 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
Run Code Online (Sandbox Code Playgroud)

编辑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
Run Code Online (Sandbox Code Playgroud)

模板.html

{{ form.field |set_attr('attr:val') }}
{{ form.field |add_class('my_class') }}
Run Code Online (Sandbox Code Playgroud)