如何渲染我的文本区域与WTForms



要使用WTForms呈现具有指定列数和行数的textarea字段,我如何设置列数和行数?我按照这个问题的说明做了,但它不起作用:

如何指定

标记

我试着添加一个小部件,但它不工作:

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's not a valid email address.'))
    ])

TypeError: object.new()不带参数

非常老的问题,但由于WTF-Form文档不清楚,我张贴我的工作示例。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 %}

此问题无需更新模板。可以在TextAreaField的定义中设置行和颜色。示例如下:

class AForm(Form):
     text = TextAreaField('Text', render_kw={"rows": 70, "cols": 11})

对于render_kw,如果提供了,则在呈现时将为小部件提供一个提供默认关键字的字典。

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>
...

我想在这里补充一下,上面建议使用render_kw的解决方案确实在文本区域的高度未设置的条件下工作。

所以如果你有一个字段:

    temp = TextAreaField('temp', render_kw={'rows':20})

在你的HTML文件中写:

    {{ form.temp(class_='someclass' )}}

那么在CSS定义的一些类,高度不应该设置,因为这将与您的行设置冲突,显然高度优先于行

最新更新