Избранное | Русский | Войти

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

HTML, встроенный в код, неупорядочен, и его трудно поддерживать. Лучше использовать систему шаблонов, в которой 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 – просто "index.html".

Подробнее о механизме шаблонов Django рассказано в документации по шаблонам Django 0.96.

Далее...

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

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