🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
New in version 2.4. 从 Jinja 2.4 开始,自动转义的首选途径就是启用 [*自动转义扩展*](http://docs.jinkan.org/docs/jinja2/extensions.html#autoescape-extension) 并为自动转义配置一个合适的默认值。这使得在单个模板基础上开关自动转义成为 可能(比如 HTML 对 文本) 这里推荐为以 .html 、 .htm 、 .xml 以及 .xhtml 的模板开启 自动转义 ,并对所有其它扩展名禁用: ~~~ def guess_autoescape(template_name): if template_name is None or '.' not in template_name: return False ext = template_name.rsplit('.', 1)[1] return ext in ('html', 'htm', 'xml') env = Environment(autoescape=guess_autoescape, loader=PackageLoader('mypackage'), extensions=['jinja2.ext.autoescape']) ~~~ 假设实现一个自动转义函数,确保你也视 None 为有效模板名接受。这会在从字符 串生成模板时传递。 可以用 autoescape 块在模板内临时地更改这种行为。(见 [*自动转义扩展*](http://docs.jinkan.org/docs/jinja2/templates.html#autoescape-overrides) )。