首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >结合Python Flask、Jinja2和Mustache

结合Python Flask、Jinja2和Mustache
EN

Stack Overflow用户
提问于 2019-06-20 22:21:10
回答 1查看 817关注 0票数 1

我正在使用Flask和jinja2的Mustache.js,在渲染图像时遇到了问题。

多亏了{% raw %}{% endraw %},我成功地在jinja中渲染了我的胡子模板,但现在我需要在我的模板中使用Jinja中的url_for()来定义我的图像源。八字胡的{{}}和金家的之间有冲突。

我的javascript:

代码语言:javascript
复制
target = document.getElementById("target");
var template = $('#my-template').html();
Mustache.parse(template);
var rendered = Mustache.render(template, {"title":"My Title","photo_name":"photo.jpg"});
target.innerHTML = rendered;

和我的模板:

代码语言:javascript
复制
<script id="my-template" type="x-tmpl-mustache">
{% raw %}
  <h1> {{title}} </h1>
  <img src="{{ url_for('static',filename='images/{{photo_name}}') }}" alt="my_photo">
{% endraw %}
</script>

你知道怎么解决这个问题吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-06-20 22:50:38

您在相当多的内容上表达了raw处理,其中一些内容您实际上并不想成为原始内容。建议您缩小{% raw %} ... {% endraw %}的范围,使其仅涵盖您希望Mustache填充的那些模板变量。例如:

代码语言:javascript
复制
<script id="my-template" type="x-tmpl-mustache">

  <h1> {% raw %}{{title}}{% endraw %} </h1>
  <img src="{{ url_for('static',filename='images/')}}{% raw %}{{photo_name}}{% endraw %}" alt="my_photo">

</script>

对于浏览器,这将呈现以下内容,然后可以使用JS /Mustache填充其模板部分:

代码语言:javascript
复制
<script id="my-template" type="x-tmpl-mustache">

  <h1> {{title}} </h1>
  <img src="/static/images/{{photo_name}}" alt="my_photo">

</script>

通过这种方式,您可以让Mustache处理特定的模板替换,而Flask / Jinja2处理其余的内容。

使用两个具有交错和重叠职责的模板引擎-更不用说相同的模板变量标记语法-使得“引用”完全必要,但也非常无聊。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56688074

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档