Context 和 APIs
GitBook 为插件提供了不同的 API 和上下文。这些 API 可以根据使用的 GitBook 版本,你的插件应该在 package.json
中指定 engines.gitbook
字段。
Book实例
Book 类是 GitBook 的中心点,它集中了所有的访问读取方法。这个类在[book.js](https://github.com/GitbookIO/gitbook/blob/master/book.js)中定义。
//从 book.json 读取配置
var value = book.config.get('title','Default Value');
//将文件名解析为绝对路径
var filepath = book.resolve('README.md');
//呈现内联标记字符串
book.renderInline('markdown','This is ** Markdown **')
.then(function(str){...})
//呈现标记字符串(块模式)
book.renderBlock('markdown','*这是** Markdown **')
.then(function(str){...})
输出实例
Output 类代表输出/写入过程。
//返回输出的根文件夹
var root = output.root();
//解析输出文件夹中的文件
var filepath = output.resolve('myimage.png');
//将文件名转换为 URL(返回html文件的路径)
var fileurl = output.toURL('mychapter / README.md');
//在输出文件夹中写入一个文件
output.writeFile('hello.txt','Hello World')
.then(function(){...});
//将文件复制到输出文件夹
output.copyFile('./ myfile.jpg','cover.jpg')
.then(function(){...});
//验证文件是否存在
output.hasFile('hello.txt')
.then(function(exists){...});
页面实例
页面实例表示当前已解析页面。
//页面标题(摘自摘要)
页面标题
//页面内容(Markdown / Asciidoc / HTML根据阶段)
page.content
//书中的相对路径
page.path
//文件的绝对路径
page.rawPath
//用于此文件的解析器的类型
page.type('markdown'或'asciidoc')
块和筛选器的上下文
块和过滤器可以访问相同的上下文,此上下文绑定到模板引擎执行:
{
//当前模板语法
"ctx":{
//例如,在{%set message =“hello”%}之后
"message":"hello"
},
// Book instance
"book":"<Book>",
//输出实例
"output":"<Object>"
}
例如,过滤器或块函数可以使用:this.book
访问当前书。
钩子的上下文
钩子只能使用 this.book
访问