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 访问 实例。

Copyright & Copy zha0cai该文件修订时间: 2024-03-28 15:32:43

results matching ""

    No results matching ""