一种快速引用 markdown 资源(markdown、图片)的方式。
在层级深的 markdown 文档结构中,如下
testdocs/
├── fsssww.md
├── imgs/
│ └── Edam.png
├── index.md
├── nodejs/
│ ├── fs.md
│ ├── index.md
│ └── module.md
├── test.md
├── test2.md
├── testss.md
├── 团队项目/
│ ├── cookbook/
│ │ ├── cookbook-v1.md
│ │ └── index.md
│ └── release-scripts/
│ └── index.md
├── 工具链/
│ └── docker/
│ └── docker.md
└── 技术栈/
├── avalon.md
└── avalon 监控属性的坑.md
我们在写一篇文章 A 的时候,想去引用(Reference)该文档中的其他文档或图片,我们需要去一层层 ../
找到对应的目录,这样引用资源繁琐。
于是便有了 quick-reference
的用武之地,quick-reference 主张扁平文件结构,在以上层级较深的结构中,会被扁平化为:
fsssww
Edam.png
index
nodejs
fs
module
test
test2
testss
cookbook
cookbook-v1
release-scripts
docker
avalon
avalon 监控属性的坑
我们可以用过下面的方式来指定扁平效果下的唯一 id
可以在文章头部指定 permalink:
---
permalink: hssss
---
如果 permalink 未被指定的话,将会使用文件名作为 permalink, 如 fs.md
被认为是 fs
,同时 nodejs/index.md
中的 index.md
的 permalink 会被认为为 nodejs
。
有了上面的扁平文件的概念之后,通过下面的语法
@link:premalink@
@link:[title]premalink@
@img:premalink@
@img:[title]premalink@
会自动转换成对应 permalink 的资源,link 转换为[...](...)
,img 转换为![](...)
效果如图展示:
npm install quick-reference -g
安装后,新增了 2 个命令 quick-ref-watch
和 quick-ref
.
安装后,在项目的 package.json 中配置 (使用cosmiconfig)
"quick-reference": {
"docRoot": "path/to/docroot"
}
# 开启文件监听服务,`-o` 表示覆写改动的文件,默认不开启
quick-ref-watch -o
# 同时可以不使用文件监听进程`-o`标志
# 使用 quick-ref 进行转换亦可
quick-ref <...md files>
在开启了 quick-ref-watch
服务(不开启-o
)后,在 IDE 中配置 quick-ref
进行 markdown 转换。
下面介绍在不同 IDE 中 quick-ref
的使用方式。