介绍

这里是 Jinjin2 通用模板语言的文档。 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_installpip 安装最新的版本的 Jinja2:

sudo easy_install Jinja2
sudo pip install Jinja2

这会在你的 Python 安装中的 site-packages 目录安装一个 Jinja2 egg 。

(如果你在 Windows 的命令行中安装,省略 sudo 并且确保你用管理员权限运行 命令行)

从 tarball 版本安装

  1. download page 下载最新的 tarball
  2. 解包 tarball
  3. sudo python setup.py install

注意这需要你已经安装了 setuptools 或 distribute ,首选后者。

这会在你 Python 安装的 site-packages 目录安装 Jinja2 。

安装开发版本

  1. 安装 git
  2. git clone git://github.com/mitsuhiko/jinja2.git
  3. cd jinja2
  4. 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 的语法。