我可以使用 Google App Engine 上的 WTForm model_form 显示我的表单。我希望在访问 /admin/newpost 时看到显示的字段
我的模特
class BlogPost(db.Model):
#The URL path to the blog post. Posts have a path if they are published.
path = db.StringProperty()
title = db.StringProperty(required=True, indexed=False)
body = db.TextProperty(required=True)
published = db.DateTimeProperty(auto_now_add=True)
updated = db.DateTimeProperty(auto_now=True)
我的 PostHandler
class PostHandler(webapp2.RequestHandler):
@webapp2.cached_property
def jinja2(self):
return jinja2.get_jinja2(app=self.app)
def render_to_response(
self,
template_name,
template_vals=None,
theme=None
):
template_name = "admin/%s" % template_name
self.response.out.write(render_template(
template_name, template_vals, theme))
def render_form(self, form):
self.render_to_response("edit.html", {'form': form()})
def get(self):
form = model_form(BlogPost)
self.render_form(form)
不起作用的 Edit.html 模板
{% extends "base.html" %}
{% block title %}New Post{% endblock %}
{% block body %}
<form method="post" action="">
<table>
{{form}}
</table>
<input type="submit" />
</form>
{% endblock %}
使用此模板,我看到带有表单按钮的 html。问题是没有显示任何模型字段。为了让我的字段显示我必须这样做......
有效的 Edit.html 模板
{% extends "base.html" %}
{% block title %}Testing New Post Template{% endblock %}
{% block body %}
<form method="post" action="">
<table>
<div>{{ form.title.label }}: {{ form.title(class="css_class") }}</div>
{% if form.title.errors %}
<ul class="errors">{% for error in form.name.errors %}<li>{{ error }}</li>{% endfor %}</ul>
{% endif %}
<div>{{ form.body.label }}: {{ form.body() }}</div>
{% if form.body.errors %}
<ul class="errors">{% for error in form.body.errors %}<li>{{ error }}</li>{% endfor %}</ul>
{% endif %}
</table>
<input type="submit" />
</form>
{% endblock %}
简而言之,如何获得第一个版本以在表单中显示我的模型字段?