介绍
这里是 Jinja2 通用模板语言的文档。 Jinja2 在其是一个 Python 2.4 库之前,被设计 为是灵活、快速和安全的。
如果你接触过其它的基于文本的模板语言,比如 Smarty 或 Django ,那么 Jinja2 会让你有 宾至如归的感觉。Jinja2 通过坚持 Python 原则来保证对设计者和开发者友好,为模板环 境添加有帮助的功能。
预备知识
Jinja2 需要至少 Python 2.4 版本来运行。此外,如果你使用 Python 2.4 ,一个可 以创建 python 扩展的可用的 C 编译器会为调试器安装。
如果你没有一个可用的 C 编译器,并且你视图安装带调试支持的源码版本,你会得到一个 编译器错误。 If you don’t have a working C-compiler and you are trying to install the source
安装
条条大路通 Jinja2 。如果你不确定怎么做,用 Python egg 或 tarball 吧。
作为一个 Python egg (通过 easy_install)
你可以用 easy_install 或 pip 安装最新的版本的 Jinja2:
sudo easy_install Jinja2 sudo pip install Jinja2
这会在你的 Python 安装中的 site-packages 目录安装一个 Jinja2 egg 。
(如果你在 Windows 的命令行中安装,省略 sudo 并且确保你用管理员权限运行 命令行)
从 tarball 版本安装
- 从 download page 下载最新的 tarball
- 解包 tarball
sudo python setup.py install
注意这需要你已经安装了 setuptools 或 distribute ,首选后者。
这会在你 Python 安装的 site-packages 目录安装 Jinja2 。
安装开发版本
- 安装 git
git clone git://github.com/mitsuhiko/jinja2.git
cd jinja2
ln -s jinja2 /usr/lib/python2.X/site-packages
作为第四步的替代选择,你也可以执行 python setup.py develop
,这会通过 disbribute 在开发模式下安装包。这样也有编译 C 扩展的优势。
加速 MarkupSafe
从 2.5.1 开始, Jinja2 会检查是否安装 MarkupSafe 模块。如果它找到了, 它会用这个模块的 Markup 类来代替自带的。 MarkupSafe 替换 Jinja2 中附带的 老的加速模块,其优势在于更好的安装脚本,自动试图安装 C 的版本并在不可行时 漂亮地退化到纯 Python 实现的版本。
MarkupSafe 的 C 实现要快得多,并推荐用于 Jinja2 自动转义。
启用调试支持模块
默认 Jinja2 不会编译调试支持模块。如果你没有 Python 头文件或可用的编译器, 启用它会失败。这当你在 Windows 上安装 Jinja2 是很常见的情况。
由于调试模式只对 Python 2.4 是必要的,所以你不需要这么做,除非你在运行 2.4:
sudo python setup.py --with-debugsupport install
基本 API 使用
本节简要介绍 Jinja2 模板的 Python API 。
最基本的方式就是通过 Template
创建一个模板并渲染它。 如果你的模板不是从字符串加载,而是文件系统或别的数据源,无论如何这都不 是推荐的方式:
>>> from jinja2 import Template >>> template = Template('Hello {{ name }}!') >>> template.render(name='John Doe') u'Hello John Doe!'
通过创建一个 Template
的实例,你会得到一个新的模板对象,提供一 个名为 render()
的方法,该方法在有字典或关键字参数时调用 扩充模板。字典或关键字参数会被传递到模板,即模板“上下文”。
如你所见, Jinja2 内部使用 unicode 并且返回值也是 unicode 字符串。所以确 保你的应用里也确实使用 unicode 。
实验性的 Python 3 支持
Jinja 2.3 带来 Python 3 的实验性支持。这意味着在新版本上,所有的单元测试 都会通过,但是仍有一些小 bug 和不一致的行为。如果你发现任何 bug ,请向 Jinja bug tracker 提供反馈。
也请记住本文档是为 Python 2 编撰的,你会需要手动把示例代码转换为 Python 3 的语法。