Skip to content

Markdown-it 中文排版美化插件,包含 pangu 和标点挤压

License

Notifications You must be signed in to change notification settings

Linho1219/markdown-it-autospace

Repository files navigation

markdown-it-autospace

NPM version License NPM Last Update npm downloads

一款可配置的 Markdown-it 插件,用于优化中文排版。

由于 pangu.js 没有对 Markdown 的支持,markdown-it-pangu 仍依赖过时项目 VuePress,且能实现标点挤压的项目 赫蹏 只能在前端运行,故博采众长,编写此插件。

功能:

  • 在汉字与英文之间添加空格(pangu);
  • 自定义需要添加空格的行内块;
  • 标点挤压(调整标点符号之间的间距,需要添加 CSS)。

效果图

Pangu

Mojikumi

你可以在使用本项目的 LinhoNotes 网站看到更多实例。

使用

npm install -D markdown-it-autospace

然后在代码中:

import mdAutoSpacing from "markdown-it-autospace";
// ...
md.use(mdAutoSpacing);

自带类型信息,若你使用 TypeScript,无需额外配置。

功能与选项

interface AutoSpacingConfig {
  pangu?: boolean;
  mojikumi?: boolean;
  spacingItems?: string[];
}

你可以像这样传入配置:

md.use(mdAutoSpacing, {
  pangu: true,
  mojikumi: true,
  spacingItems: ["code_inline", "math_inline"],
});

pangu

boolean,默认值为 true

是否自动在汉字与数字、字母间添加空格。

此功能的实现基于 pangu.js

mojikumi

boolean,默认值为 false

是否执行标点挤压。

Warning

此功能需要配合 CSS 实现。你应当在渲染结果所在的页面上添加如下 CSS:

punc-spacing {
  display: inline;
}
.punc-half {
  margin-inline-end: -1em;
}
.punc-half {
  margin-inline-end: -0.5em;
}
.punc-quarter {
  margin-inline-end: -0.25em;
}
.punc-before-less {
  margin-inline-start: -0.4em;
}
.punc-before-more {
  margin-inline-start: -0.5em;
}

你也可以直接引入 markdown-it-autospace/spacing.css。空隙大小可按个人喜好调整。

此功能的实现离不开 赫蹏

spacingItems

string[],默认值为 ["code_inline", "math_inline"]

指定需要在前后添加空格的 Markdown-it token。留空时默认对行内代码块与行内公式启用,如不需要此功能,请传入 []

此功能的实现离不开 markdown-it-pangu

About

Markdown-it 中文排版美化插件,包含 pangu 和标点挤压

Resources

License

Stars

Watchers

Forks

Packages

No packages published