Flask WTF表单在表单字段中添加glyphicon

时间:2016-09-15 21:51:22

标签: python html twitter-bootstrap flask wtforms

我有一个Flask Wtf表格如下:

class URL_Status(Form):
    url = URLField("Enter URL",
                       validators=[url(), DataRequired()],
                       render_kw={"placeholder": "http://www.example.com"},)
    submit = SubmitField('Search', render_kw={"onclick": "loading()"})

现在我想在输入字段中添加一个bootstrap glyphicon,即'url'。据我所知link。我们需要编写如下代码:

<div class="form-group has-feedback">
    <label class="control-label">Username</label>
    <input type="text" class="form-control" placeholder="Username" />
    <i class="glyphicon glyphicon-user form-control-feedback"></i>
</div>

当我在HTMl中调用表单时,我的html会创建除此行之外的所有代码:

<i class="glyphicon glyphicon-user form-control-feedback"></i>

任何建议如何从我的班级'URL_Status'添加此行,以便我能够看到带有输入字段的glyphicon。感谢

3 个答案:

答案 0 :(得分:1)

我暂时没有使用过wtforms。我认为你需要一个自定义小部件:

class CustomURLInput(URLInput):
    ...
    def __call__(self,....):
        ...

看看这个https://github.com/wtforms/wtforms/blob/9be964158fbcd1af52b345451bbd14751127dd37/wtforms/widgets/core.py#L159 详情。

和您的网址字段:

url = URLField(
    "Enter URL",
    validators=[url(), DataRequired()],
    render_kw={"placeholder": "http://www.example.com"},
    widget=CustomURLWidget()
)

或者您可以在模板中执行此操作。

答案 1 :(得分:1)

这是解决这个问题的一个小技巧。

CSS:

.user-icon {
padding-left:30px;
background-repeat: no-repeat;
background-position-x: 4px;
background-position-y: 4px;
background-image: url();}

模板:

<form class="form form-horizontal" method="POST">
    {{ form.hidden_tag() }}
    {{ form.username(class_="form-control user-icon") }}
    {{ form.password }}
    {{ form.submit }}
</form>

此解决方案基于this answer。它只是使用base64 URI编码将glyphicon的图像表示直接嵌入到CSS中。

您可以在此site上获取glyphicon的base64数据。此外,您还可以使用image(25 * 25)替换base64数据。像这样:

background-image: url({{ url_for('static', filename='user.png') }});

答案 2 :(得分:1)

您可以使用jinja2宏在表单中渲染glyphicon,然后导入您在当前html中创建的宏

示例: 1.创建一个带有以下宏的html文件(例如:“ _ form_macro.html”):

{% macro render_field(field) %}

    <dt>{{ field.label }}
    <dd>{{ field(**kwargs)|safe }}
            <span class="add-on form_input"><i class="icon-calendar fa-border form_input"></i></span>

    {% if field.errors %}
        <ul class=errors>
        {% for error in field.errors %}
            <li>{{ error }}</li>
        {% endfor %}
        </ul>
    {% endif %}
    </dd> 
{% endmacro %}
  1. 使用以下命令将宏导入您当前的html中:
{% from "_form_macro.html" import render_field %}
  1. 使用您创建的宏来呈现表单,如下所示:
{{ forms.form_name.label_tag }}
{{ render_field(forms.form_name, type="yourtype", class="yourclass") }}
  1. 检查http://jinja.pocoo.org/docs/2.10/templates/以获得有关宏的更多信息