Jinja 提供了用?[Babel](http://babel.edgewall.org/)?抽取器從模板中抽取 gettext 消息的支持,抽取器的接入點 名為jinja2.ext.babel_extract?。 Babel 支持的被作為?[*i18n 擴展*](http://docs.jinkan.org/docs/jinja2/extensions.html#i18n-extension)?的 一部分實現。
Gettext 消息從?trans?標簽和代碼表達式中抽取。
要從模板中抽取 gettext 消息,項目需要在它的 Babel 抽取方法?[mapping file](http://babel.edgewall.org/wiki/Documentation/messages.html#extraction-method-mapping-and-configuration)?中 有一個 Jinja2 節:
~~~
[jinja2: **/templates/**.html]
encoding = utf-8
~~~
Environment?的語法相關選項也可作為 mapping file 的配置值。例如告知 抽取器模板使用?%作為?line_statement_prefix?你可以這樣寫:
~~~
[jinja2: **/templates/**.html]
encoding = utf-8
line_statement_prefix = %
~~~
[*擴展*](http://docs.jinkan.org/docs/jinja2/extensions.html#jinja-extensions)?可能也被定義為傳遞一個逗號分割的導入路徑列表作為?extensions?值。 i18n 擴展會被自動添加。
Changed in version 2.7:?直到 2.7 模板語法錯誤始終被忽略。因為許多人在模板文件夾中放置非模板的 html 文件,而這會隨機報錯,所以如此設定。假定是無論如何測試套件會捕獲 模板中的語法錯誤。如果你不想要這個行為,你可以在設置中添加?slient=flase?,異常會被傳播。
- 介紹
- 預備知識
- 安裝
- 基本 API 使用
- 實驗性的 Python 3 支持
- API
- 基礎
- Unicode
- 高層 API
- 自動轉義
- 標識符的說明
- 未定義類型
- 上下文
- 加載器
- 字節碼緩存
- 實用工具
- 異常
- 自定義過濾器
- 求值上下文
- 自定義測試
- 全局命名空間
- 低層 API
- 元 API
- 沙箱
- API
- 運算符攔截
- 模板設計者文檔
- 概要
- 變量
- 過濾器
- 測試
- 注釋
- 空白控制
- 轉義
- 行語句
- 模板繼承
- HTML 轉義
- 控制結構清單
- 導入上下文行為
- 表達式
- 內置過濾器清單
- 內置測試清單
- 全局函數清單
- 擴展
- 自動轉義擴展
- 擴展
- 添加擴展
- i18n 擴展
- 表達式語句
- 循環控制
- With 語句
- 自動轉義擴展
- 編寫擴展
- 集成
- Babel 集成
- Pylons
- TextMate
- Vim
- 從其它的模板引擎切換
- Jinja1
- Django
- Mako
- 提示和技巧
- Null-Master 退回
- 交替的行
- 高亮活動菜單項
- 訪問父級循環