Evgenii Legotckoi
05 січня 2019 р. 20:49

Django - Підручник 042. Кешування шаблонів для різних типів контенту

Зміст

У Django - Урок 035. Різні шаблони для відображення різних типів контенту в пошуковій видачі було показано, як малювати різні шаблони залежно від того, який тип контенту відображається у результатах пошуку на сайті. При цьому ключовим моментом було те, що не потрібно створювати умови перевірки вибору шаблону. Інформація про балбалон зберігалася в змінній TEMPLATE_PREVIEW, через яку шаблон був вставлений у включений тег шаблону Django.

  1. {% include object.TEMPLATE_PREVIEW %}

У цьому способі є одна велика вада. Справа в тому, що тег include при кожному своєму виклик шукає шаблон. При великому навантаженні на сайт це може значно збільшити тривалість відповіді від сервера. Щоб вирішити цю проблему, потрібно якось кешувати патерн. Оскільки для різних типів контенту використовуються різні шаблони, це зробити за допомогою include_tag досить проблематично.

Ця проблема була вирішена шляхом кешування шаблону на рівні класу як змінної класу.


Цей механізм можна реалізувати з допомогою міксину.

  1. class EInterfaceMixin:
  2. TEMPLATE_FULL = 'full.html' # путь к шаблону
  3. template_full = None # pattern caching variable
  4.  
  5. # we will cache with the help of the class method, in which we pass the object for rendering, as well as the context of the request
  6. # request context is required to provide rendering functionality that is dependent on the current user
  7. @classmethod
  8. def __render_template_full(cls, obj, request_context):
  9. if not cls.template_full:
  10. cls.template_full = loader.get_template(cls.TEMPLATE_FULL)
  11. return cls.template_full.render({'object': obj, 'user': request_context['user']})
  12.  
  13. # method to render using context
  14. def render_template_full(self, request_context):
  15. return self.__render_template_full(self, request_context)

Далі слід зареєструвати вбудований тег. Це потрібно для того, щоб при рендерингу шаблону підібрати контекст запиту. У моєму випадку частина шаблонів не може коректно відображатись без інформації про поточного користувача, який знаходиться на сайті.

  1. @register.simple_tag(takes_context=True)
  2. def render_template_full(context, obj):
  3. if obj:
  4. return obj.render_template_full(context)
  5. return ''

Використовуйте в шаблоні

  1. {% load render_template_full from core %}
  2. {% for object in object_list %}
  3. {% render_template_full object %}
  4. {% empty %}

Висновок

Цей міксин можна додати до всіх моделей, які використовуватимуть цей двигун рендеринга.

При першому виклику методу класу шаблон кешується. При наступних викликах рендерингу буде використовуватися кешований шаблон. Таким чином, не буде марної витрати процесорного часу на пошук шаблону при кожному виклику тега include

Вам це подобається? Поділіться в соціальних мережах!

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
  • Останні коментарі
  • Evgenii Legotckoi
    16 квітня 2025 р. 17:08
    Благодарю за отзыв. И вам желаю всяческих успехов!
  • IscanderChe
    12 квітня 2025 р. 17:12
    Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
  • AK
    01 квітня 2025 р. 11:41
    Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
  • Evgenii Legotckoi
    09 березня 2025 р. 21:02
    К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
  • VP
    09 березня 2025 р. 16:14
    Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…