2016-09-15 4 views
0

У меня есть форма Колба Wtf следующим образом:Колба WTF формы добавляя glyphicon в поле формы

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()"}) 

теперь я хотел бы добавить самозагрузки 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> 

Любые предложения, как я могу добавить эту строку из моего class 'URL_Status', чтобы я мог видеть глификон с моим полем ввода. Спасибо

+0

Возможный дубликат [Добавить Bootstrap Glyphicon в поле ввода] (http://stackoverflow.com/questions/18838964/add-bootstrap-glyphicon-to-input-box) –

+0

Я не создавая форм с использованием HTML. Я создаю формы с сервера с помощью wtf. –

+0

Я решил вашу проблему, дайте ей попробовать! –

ответ

1

Я не использовал wtforms через некоторое время. Я думаю, что вам нужен собственный виджет:

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

Взгляните на эту https://github.com/wtforms/wtforms/blob/9be964158fbcd1af52b345451bbd14751127dd37/wtforms/widgets/core.py#L159 для деталей.

и ваше поле URL:

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

Или вы можете сделать это в шаблоне.

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. Он просто встраивает представление изображения глификона непосредственно в CSS с использованием кодировки URI base64.

Вы можете получить базовые данные глификона на этом site. Кроме того, вы можете использовать изображение (25 * 25) для замены данных base64. Как это:

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