Skip to content

Set link or image reference in markdown quickly and easily

Notifications You must be signed in to change notification settings

be-fe/quick-reference

Repository files navigation

quick-reference

build status Test coverage NPM version NPM Downloads

一种快速引用 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-watchquick-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 的使用方式。

WebStorm JetBrain

方式一 (External Tools,快捷键触发)

  • Preferences - External Tools

  • New Tool

  • Enable quick-reference, and apply the setting.

  • Set Keymap for run quick-reference

方法二(File Watcher,监控文件修改自动执行)

About

Set link or image reference in markdown quickly and easily

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published