💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
默认下,每个包含的模板会被传递到当前上下文,而导入的模板不会。这样做的原因 是导入量不会像包含量被缓存,因为导入量经常只作容纳宏的模块。 无论如何,这当然也可以显式地更改。通过在 import/include 声明中直接添加 with context 或 without context ,当前的上下文可以传递到模板,而且不会 自动禁用缓存。 这里有两个例子: ~~~ {% from 'forms.html' import input with context %} {% include 'header.html' without context %} ~~~ 提示 在 Jinja 2.0 中,被传递到被包含模板的上下文不包含模板中定义的变量。 事实上,这不能工作: ~~~ {% for box in boxes %} {% include "render_box.html" %} {% endfor %} ~~~ 在 Jinja 2.0 中,被包含的模板 render_box.html *不能* 访问 box 。从 Jinja 2.1 开始,render_box.html *可以* 这么做。