Как визуализировать мою TextArea с помощью WTForms?
Чтобы отобразить мое текстовое поле с указанным числом столбцов и строк с помощью WTForms, как установить количество столбцов и строк? Я выполнил инструкции по этому вопросу, но это не сработало:
Как указать строки и столбцы в <textarea> тег с использованием wtforms
Я попробовал добавить виджет, но он не работал:
class AForm(Form):
name = TextField('Name', [validators.Length(min=4)])
title = TextField('Title', [validators.Length(min=4)])
text = TextAreaField('Text', widget=TextArea(row=70, cols=11))
phonenumber = TextField('Phone number')
phonenumberhide = BooleanField('Display phone number on site')
price = TextField('Price')
password = PasswordField('Password')
email = TextField('Email', [
validators.Length(min=6, message=_('Little short for an email address?')),
validators.Email(message=_('That\ not a valid email address.'))
])
TypeError: object. новый() не принимает параметров
Ответы
Ответ 1
Очень старый вопрос, но поскольку документация WTF-формы не ясна, я отправляю свой рабочий пример. OP, надеюсь, вы еще не работаете над этим.: -)
форма
from flask_wtf import Form
from wtforms.fields import StringField
from wtforms.widgets import TextArea
class PostForm(Form):
title = StringField(u'title', validators=[DataRequired()])
body = StringField(u'Text', widget=TextArea())
шаблон
{% extends "base.html" %}
{% block title %}Create Post{% endblock %}
{% block content %}
<H3>Create/Edit Post</H3>
<form action="" method=post>
{{form.hidden_tag()}}
<dl>
<dt>Title:
<dd>{{ form.title }}
<dt>Post:
<dd>{{ form.body(cols="35", rows="20") }}}
</dl>
<p>
<input type=submit value="Publish">
</form>
{% endblock %}
Ответ 2
TextArea
поле также может быть реализовано без каких-либо виджетов:
forms.py
from wtforms import Form, TextField, TextAreaField
class ContactForm(Form):
name = TextField('Name')
email = TextField('Email Address')
body = TextAreaField('Message Body')
template.html
...
<form method="POST" action="">
{{ form.csrf_token }}
{{ form.name.label }} {{ form.name(size=30) }} <br/>
{{ form.email.label }} {{ form.email(size=30) }} <br/>
{{ form.body.label }} {{ form.body(cols="35", rows="20") }} <br/>
<input type="submit" value="Submit"/>
</form>
...
Ответ 3
Нет необходимости обновлять шаблон для этой проблемы. Вы можете установить строки и столбцы в определении TextAreaField
. Вот пример:\
class AForm(Form):
text = TextAreaField('Text', render_kw={"rows": 70, "cols": 11})
Для render_kw
, если предоставлено, словарь, который предоставляет ключевые слова по умолчанию, будет предоставлен виджету во время рендеринга.