nunjucks具有越来越强大的Jinja兼容模式。如果我包括完整的nunjucks,我可以在渲染模板之前使用它调用nunjucks.installJinjaCompat()
(请参见下面的摘要(:
nunjucks.installJinjaCompat();
var res = nunjucks.renderString(
'{% for i in list[0:2] %}' +
' count: {{ i }}' +
'{% endfor %}',
{list: [1, 2, 3, 4]}
);
document.write(res);
<script src="https://cdnjs.cloudflare.com/ajax/libs/nunjucks/3.0.1/nunjucks.min.js"></script>
我无法弄清楚如何预编译相同的代码。拥有文件list.njk
:
{% for i in list[0:2] %}
count: {{ i }}
{% endfor %}
i使用默认nunjucks-precompile list.njk > list.js
命令进行预编译,但它提高了:
/usr/local/lib/node_modules/nunjucks/src/precompile.js:130
throw lib.prettifyError(name, false, err);
^
Template render error: (list.njk) [Line 1, Column 15]
parseAggregate: expected comma after expression
at Object.exports.prettifyError (/usr/local/lib/node_modules/nunjucks/src/lib.js:34:15)
at _precompile (/usr/local/lib/node_modules/nunjucks/src/precompile.js:130:19)
at precompile (/usr/local/lib/node_modules/nunjucks/src/precompile.js:79:27)
at Object.<anonymous> (/usr/local/lib/node_modules/nunjucks/bin/precompile:62:13)
at Module._compile (module.js:409:26)
at Object.Module._extensions..js (module.js:416:10)
at Module.load (module.js:343:32)
at Function.Module._load (module.js:300:12)
at Function.Module.runMain (module.js:441:10)
at startup (node.js:139:18)
错误,如果我使用阵列剪接,那是Jinja兼容的特定构造。如果我删除[0:2]
。
我如何预编译模板出现Jinja Compat模式?
我已经尝试在文档中找到此问题,nunjucks发出了问题并检查nunjucks
变量的nunjucks-precompile
节点脚本,以便我可以使用monkeypatch,包括 nunjucks.installJinjaCompat()
call;可悲的是它不存在,它只使用Environment
。
看起来nunjucks-precompile
没有nunjucks.installJinjaCompat()
的开关,但是您可以很容易地添加:
复制现有的CLI文件并将其修改以纠正要求源并安装组合层:
cp node_modules/.bin/nunjucks-precompile .
<edit nunjucks-precompile>
./nunjucks-precompile list.njk
...
使用Nunjucks 3.0.1
./nunjucks-precompile
看起来像
#!/usr/bin/env node
var path = require('path');
var precompile = require('nunjucks/src/precompile').precompile;
var Environment = require('nunjucks/src/environment').Environment;
var lib = require('nunjucks/src/lib');
var nunjucks = require('nunjucks');
nunjucks.installJinjaCompat();
...
,也可以从这里下载。