嵌入代码中的 HTML 杂乱且难以维护。最好使用模板系统,在模板系统中,HTML 会保存在单独的文件中,且使用特殊语法来表示来自应用程序的数据要显示的位置。适用于 Python 的模板系统有很多:EZT、Cheetah、ClearSilver、Quixote 和 Django,而这些只是其中的一小部分。您可以通过将选择的模板引擎与您的应用程序代码绑定来使用该模板引擎。
方便起见,webapp 模块将包含 Django 的模板引擎。这包括在 SDK 中,并且是 App Engine 的一部分,因此您无需将其绑定便可使用它。
在 helloworld/helloworld.py 顶部添加以下 import 语句:
import os from google.appengine.ext.webapp import template
用类似以下的代码替换 MainPage 处理程序:
class MainPage(webapp.RequestHandler):
def get(self):
greetings_query = Greeting.all().order('-date')
greetings = greetings_query.fetch(10)
if users.get_current_user():
url = users.create_logout_url(self.request.uri)
url_linktext = 'Logout'
else:
url = users.create_login_url(self.request.uri)
url_linktext = 'Login'
template_values = {
'greetings': greetings,
'url': url,
'url_linktext': url_linktext,
}
path = os.path.join(os.path.dirname(__file__), 'index.html')
self.response.out.write(template.render(path, template_values))
最后,在 helloworld 目录中创建一个名为 index.html 的新文件,内容如下:
<html>
<body>
{% for greeting in greetings %}
{% if greeting.author %}
<b>{{ greeting.author.nickname }}</b> wrote:
{% else %}
An anonymous person wrote:
{% endif %}
<blockquote>{{ greeting.content|escape }}</blockquote>
{% endfor %}
<form action="/sign" method="post">
<div><textarea name="content" rows="3" cols="60"></textarea></div>
<div><input type="submit" value="Sign Guestbook"></div>
</form>
<a href="{{ url }}">{{ url_linktext }}</a>
</body>
</html>
重新加载该页面并进行尝试。
template.render(path, template_values) 将获取到该模板文件的文件路径和值参照表,然后返回呈现的文本。该模板使用 Django 模板语法来访问值并将这些值进行循环,而且可以参考这些值的属性。在许多情况下,您可以将数据存储区 Model 对象作为值直接传递,并从模板访问其属性。
提示:App Engine 应用程序对通过项目、库模块上传的所有文件(不包括其他文件)仅有只读访问权限。当前工作目录是应用程序根目录,所以到 index.html 的路径就是 "index.html"。
有关 Django 模板引擎的详细信息,请参阅 Django 0.96 模板文档。
每个网络应用程序都可通过模板或一些其他机制,返回从应用程序代码动态生成的 HTML。大部分网络应用程序还需要提供静态内容,例如图像、CSS 样式表或 JavaScript 文件。为了提高效率,App Engine 对静态文件的处理方式与对应用程序源和数据文件的处理方式不同。您可以使用 App Engine 的静态文件功能来为该应用程序提供 CSS 样式表。
继续转至使用静态文件。