- 1. Висновок
У Django - Урок 035. Різні шаблони для відображення різних типів контенту в пошуковій видачі було показано, як малювати різні шаблони залежно від того, який тип контенту відображається у результатах пошуку на сайті. При цьому ключовим моментом було те, що не потрібно створювати умови перевірки вибору шаблону. Інформація про балбалон зберігалася в змінній TEMPLATE_PREVIEW, через яку шаблон був вставлений у включений тег шаблону Django.
{% include object.TEMPLATE_PREVIEW %}
У цьому способі є одна велика вада. Справа в тому, що тег include при кожному своєму виклик шукає шаблон. При великому навантаженні на сайт це може значно збільшити тривалість відповіді від сервера. Щоб вирішити цю проблему, потрібно якось кешувати патерн. Оскільки для різних типів контенту використовуються різні шаблони, це зробити за допомогою include_tag досить проблематично.
Ця проблема була вирішена шляхом кешування шаблону на рівні класу як змінної класу.
Цей механізм можна реалізувати з допомогою міксину.
class EInterfaceMixin: TEMPLATE_FULL = 'full.html' # путь к шаблону template_full = None # pattern caching variable # 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 # request context is required to provide rendering functionality that is dependent on the current user @classmethod def __render_template_full(cls, obj, request_context): if not cls.template_full: cls.template_full = loader.get_template(cls.TEMPLATE_FULL) return cls.template_full.render({'object': obj, 'user': request_context['user']}) # method to render using context def render_template_full(self, request_context): return self.__render_template_full(self, request_context)
Далі слід зареєструвати вбудований тег. Це потрібно для того, щоб при рендерингу шаблону підібрати контекст запиту. У моєму випадку частина шаблонів не може коректно відображатись без інформації про поточного користувача, який знаходиться на сайті.
@register.simple_tag(takes_context=True) def render_template_full(context, obj): if obj: return obj.render_template_full(context) return ''
Використовуйте в шаблоні
{% load render_template_full from core %} {% for object in object_list %} {% render_template_full object %} {% empty %}
Висновок
Цей міксин можна додати до всіх моделей, які використовуватимуть цей двигун рендеринга.
При першому виклику методу класу шаблон кешується. При наступних викликах рендерингу буде використовуватися кешований шаблон. Таким чином, не буде марної витрати процесорного часу на пошук шаблону при кожному виклику тега include