Использование шаблонов

Использование HTML напрямую в коде приложения приводит к сложностям в его сопровождении. Альтернативным вариантом является использование шаблонной системы, которая позволяет отделять дизайн приложения от его кода. Для языка Python доступны множество шаблонных систем: EZT, Cheetah, ClearSilver, Quixote, Django и многие другие. Вы можете разместить выбранный фреймворк вместе со своим приложением, скопировав его код в рабочий каталог приложения.

Для удобства разработчика модуль webapp уже включает в себя шаблонную систему Django. Она поставляется как с SDK так и в составе платформы App Engine, поэтому нет необходимости загружать ее на сервер вместе с приложением.

Использование шаблонов Django

Добавьте следующие операторы import в начало файла helloworld/helloworld.py:

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. В большинстве случаев можно передавать объекты из хранилища напрямую в шаблон, который затем получит их значения.

Подсказка: Приложения платформы App Engine имеют доступ к своим файлам исключительно в режиме "только для чтения". Значение текущего каталога совпадает с именем корневого каталога, таким образом, нет необходимости указывать путь к файлу с шаблоном index.html.

Для дополнительной информации о шаблонах Django обратитесь к руководству шаблонной системы Django 0.96.

Далее...

Каждое web приложение с помощью шаблонов или другим способом генерирует динамически созданный HTML код. Однако большинству приложений вместе с тем требуется отдавать статические файлы в неизменном виде, такие как изображения, стили CSS, код JavaScript. Для повышения эффективности платформа App Engine может обслуживать работу как кода приложения, так и файлов со статическим содержимым. Мы будем использовать возможности App Engine в своем приложении для реализации поддержки файлов с стилями CSS.

Перейти к Использование статических файлов.