小书匠Nunjucks语法详解:模板引擎与自定义标签

需积分: 0 0 下载量 139 浏览量 更新于2024-08-05 收藏 346KB PDF 举报
"小书匠语法说明之nunjucks1" 小书匠是一款强大的文档编辑工具,它引入了nunjucks模板引擎,使得用户在编辑文档时能够利用更丰富的语法结构。nunjucks是一个功能强大的模板语言,具有继承、异步控制等特性,并受到了jinja2的启发。通过nunjucks,用户可以编写更加灵活和结构化的文档内容。 **内部处理流程** 小书匠使用nunjucks的主要过程包括以下几个步骤: 1. **替换内代码和块代码为占位符**:在用户输入的文档中,小书匠会识别出nunjucks的内联代码(如`{{ }}`)和块代码(如`{% %}`),并将它们替换为临时的占位符,以便后续处理。 2. **nunjucks引擎解析**:接着,小书匠使用nunjucks引擎对文档进行解析,执行模板引擎的逻辑,如变量替换、条件判断、循环等。 3. **占位符还原**:解析完成后,小书匠将占位符再次转换回原始的nunjucks代码,确保markdown引擎可以正确地处理这些代码。 4. **markdown引擎处理**:最后,小书匠使用markdown引擎将文档转化为富文本格式,以便于展示和阅读。 **内置变量** 小书匠提供了两个内置变量供用户在nunjucks模板中使用: - `doc`:代表当前文档对象,包含文档的所有信息。 - `meta`:存储文档的元数据,例如作者、创建日期等。 **标签支持** 小书匠支持多种nunjucks标签,如`if`、`for`、`block`等,同时还有自定义标签,如`youtube`、`vimeo`和`slideshare`,用于方便插入视频和幻灯片分享链接。此外,还支持`call`标签来调用函数,以及`filter`标签应用过滤器。 **过滤器** 过滤器在nunjucks中用于修改变量的值。小书匠提供了自定义过滤器,如`numbo`用于数字转换为文字,以及`date`用于格式化时间。同时,它也支持nunjucks原生的过滤器。 **注意事项** 用户需要注意,不是所有的nunjucks标签都在小书匠中支持,有些可能因为安全或兼容性原因未被实现。对于不支持的标签,用户需要寻找替代方案。 小书匠与nunjucks的结合为用户提供了更高级别的文档编辑体验,让用户可以通过模板语法实现更复杂的内容结构和逻辑。通过熟练掌握nunjucks的语法,用户可以编写出更具交互性和动态性的文档。