- NOTE: This library is still under development, so API may change. Please do not use it in production environment.
JavaScript library that reads Markdown files and generates JSON-based blog posts, supporting Yaml Front Matter and GitHub Flavored Markdown.
npm i marksonjs
import { markson } from 'marksonjs';
let posts = markson.scan('./posts'); // scan markdown files in dir, returns an array
let post = markson.read('./posts/post.md'); // read single markdown file, returns an object
The default options are as follows. Configure Markson as initialization if needed.
import { Markson } from 'marksonjs';
const markson = new Markson({
gfm: true, // enable github-flavored-markdown
cleanText: false, // if enabled, exports clean text without html tags and white spaces
frontmatter: true, // if enabled, parse front matters in markdown files
rawMD: false, // if enabled, exports raw markdown content
exportHTML: true, // if enabled, exports parsed html string
slug: 'filename', // specify what to use as slug, filename or 'slug' attribute in front matter
});
Parameter:
- filename - path to the source markdown file
Returns: Object formed like this
{
type: 'file',
filename: '.../markdown-file.md',
data: {
slug: '...',
title: '...',
date: 'Date String',
attributes: {
// front matter here
}
html: '...',
}
}
Parameter:
- dir - path to the source directory
Returns: Array formed like this
[
{
type: 'directory',
filename: '.../sub-directory/',
data: [
{
type: 'file',
// ...
},
{
type: 'directory',
// ...
}
],
},
{
type: 'file',
filename: '.../file.md',
data: {
slug: '...',
title: '...',
date: 'Date String',
attributes: {
// front matter here
}
html: '...',
}
}
]
Parameters:
- source - similar to
filename
/dir
inread()
/scan()
method - destination - where to write output, default
./output.json
- type -
dir
orfile
, decides to usescan()
orread()
, defaultdir
Returns: Boolean that indicates if file is written