如何从另一个模板中包含的模板中渲染烧瓶中的WTF表单?

时间:2018-03-06 12:22:55

标签: python flask jinja2 wtforms

我想在home.html页面中包含WTF表单的模板,如下所示:{%include“users / register.html”%},同时保留呈现home.html和表单register.html的代码如下所示分开。

我的主页'home.html'正在我的'app.py'文件中的'index()'函数路由。

'app.py'还会注册'views.py'文件中定义的蓝图'user_blueprint'。

我有一个函数'sign_up',它在名为'register.html'的模板中呈现wtf表单。

在home.html中我想这样做:{%include“users / register.html”%}。我的理解是,这不起作用,因为表单没有传递给home.html,包括home.html中的register.html就像复制它一样,表单对象不会传递给home.html

如何在保持蓝图的同时渲染模板'register.html'(而不仅仅是将表单复制到'index()')?虽然这可能不是最好的方法,但在这种情况下你会建议什么?感谢

app.py

import...

app = Flask(__name__)
app.config.from_object('config')
app.secret_key = "123"

UPLOAD_FOLDER = os.path.join(app.root_path, 'static/img/products/')
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER


@app.before_first_request
def init_db():
    Database.initialize()


@app.route('/')
@app.route('/home')
def index():
    products = Product.find_all()
    return render_template('home.html', title='Home', products=products)

app.register_blueprint(user_blueprint, url_prefix="/users")

views.py

user_blueprint = Blueprint('users', __name__)


class RegisterUser(FlaskForm):
    first_name = StringField('first_name', validators=[DataRequired()])
    last_name = StringField('last_name', validators=[DataRequired()])
    email = StringField('email', validators=[DataRequired()])
    password = StringField('password', validators=[DataRequired()])


@user_blueprint.route('/register', methods=['GET', 'POST'])
def sign_up():
    form = RegisterUser(request.form)
    if request.method == 'POST' and form.validate():
        first_name = form.first_name.data
        last_name = form.last_name.data
        email = form.email.data
        password = form.password.data
        print(first_name)

    try:
        if User.register_user(first_name, last_name, email, password):
            session['email'] = email
            return redirect(url_for("index"))
    except UserErrors.UserError as e:
        return e.message

    return render_template('users/register.html')  

return render_template('users/register.html', form=form)

register.html

{% from "_formhelpers.html" import render_field %}
<form method=post>
    <dl>
        {{ render_field(form.first_name) }}
        {{ render_field(form.last_name) }}
        {{ render_field(form.email) }}
        {{ render_field(form.password) }}
    </dl>
    <p><input type=submit value=register>
</form>

home.html,不包括不相关的HTML

{% include "users/register.html" %}

1 个答案:

答案 0 :(得分:1)

我的方法是将表单通过home.html路由传递给index()并使用{% include "users/register.html" %}将其包含到您的家中,然后将表单的操作注册到处理表单的sign_up()路由。

这样,您可以在单独的路线上保持表格和表格处理的显示...然后在sign_up()路线中处理表格后,您可以将用户引导至任何其他页面。 / p>