Я пытаюсь скрыть HTML-шаблон в HTML для mustache.js, однако механизм шаблонов django удаляет все заполнители, которые должен быть выводиться как есть для внешнего интерфейса
Шаблон включается в HTML следующим образом:
<script type="text/x-mustache-template" data-id="header_user_info">
<div id="header_user_info">
<div id="notification">0</div>
<a href="#">{{username}}</a>
</div>
</script>
и я могу получить шаблон HTML, запустив $ (el) .html (), и сгенерировать html с помощью Mustache.to_html (temp, data);
Я мог бы поместить весь шаблон в другой статический файл и обслуживать его из CDN, но тогда было бы трудно отследить где принадлежит шаблон, и хотя бы один дополнительный HTTP-запрос.
У меня та же проблема, но использование
{% templatetag openvariable %} variable {% templatetag closevariable %}
слишком многословно для меня. Я только что добавил очень простой пользовательский тег шаблона:
@register.simple_tag
def mtag(tagContent):
return "{{%s}}" % tagContent
Теперь я могу написать:
{% mtag "variable" %}
У меня та же проблема, поэтому большую часть времени мои переменные являются частью переводимой строки.
{% trans "The ball is {{ color }}" %}
Вы можете использовать тег trans templatetag, даже если вы не предлагаете i18n.
Вы можете использовать встроенный разделительный тег mustache.js, чтобы изменить теги по умолчанию, используемые усами.
, т.е.
{{=<% %>=}}
Теперь вы можете сделать это:
<% variable %>
Попробуйте использовать django-mustachejs
{% load mustachejs %}
{% mustachejs "main" %}
Django-mustachejs создаст следующее:
<script>Mustache.TEMPLATES=Mustache.TEMPLATES||{};Mustache.TEMPLATES['main']='<<Your template >>';</script>
Если вы используете django 1.5 и новее, используйте:
{% verbatim %}
{{if dying}}Still alive.{{/if}}
{% endverbatim %}
Если вы застряли с django 1.2 в appengine, расширьте синтаксис django с помощью команды verbatim template следующим образом ...
from django import template
register = template.Library()
class VerbatimNode(template.Node):
def __init__(self, text):
self.text = text
def render(self, context):
return self.text
@register.tag
def verbatim(parser, token):
text = []
while 1:
token = parser.tokens.pop(0)
if token.contents == 'endverbatim':
break
if token.token_type == template.TOKEN_VAR:
text.append('{{')
elif token.token_type == template.TOKEN_BLOCK:
text.append('{%')
text.append(token.contents)
if token.token_type == template.TOKEN_VAR:
text.append('}}')
elif token.token_type == template.TOKEN_BLOCK:
text.append('%}')
return VerbatimNode(''.join(text))
В вашем файле (python 2.7, HDR) используйте:
from django.template import Context, Template
import django
django.template.add_to_builtins('utilities.verbatim_template_tag')
html = Template(blob).render(Context(kwdict))
В вашем файле (python 2.5) используйте:
from google.appengine.ext.webapp import template
template.register_template_library('utilities.verbatim_template_tag')
Источник: http : //bamboobig.blogspot.co.at/2011/09/notebook-using-jquery-templates-in.html