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)?)。
- 介紹
- 預備知識
- 安裝
- 基本 API 使用
- 實驗性的 Python 3 支持
- API
- 基礎
- Unicode
- 高層 API
- 自動轉義
- 標識符的說明
- 未定義類型
- 上下文
- 加載器
- 字節碼緩存
- 實用工具
- 異常
- 自定義過濾器
- 求值上下文
- 自定義測試
- 全局命名空間
- 低層 API
- 元 API
- 沙箱
- API
- 運算符攔截
- 模板設計者文檔
- 概要
- 變量
- 過濾器
- 測試
- 注釋
- 空白控制
- 轉義
- 行語句
- 模板繼承
- HTML 轉義
- 控制結構清單
- 導入上下文行為
- 表達式
- 內置過濾器清單
- 內置測試清單
- 全局函數清單
- 擴展
- 自動轉義擴展
- 擴展
- 添加擴展
- i18n 擴展
- 表達式語句
- 循環控制
- With 語句
- 自動轉義擴展
- 編寫擴展
- 集成
- Babel 集成
- Pylons
- TextMate
- Vim
- 從其它的模板引擎切換
- Jinja1
- Django
- Mako
- 提示和技巧
- Null-Master 退回
- 交替的行
- 高亮活動菜單項
- 訪問父級循環