mark-dom
Mark-dom is basically jQuery but for markdown.
If you've ever wanted to write a script that only edits a single part of a markdown doc and leaves the rest alone, then hopefully this brings you joy.
Install
$ npm install mark-dom
Example
Our Example Markdown
<!-- This is some markdown --># Hello thereI am some markdown## Dogs are coolThey bring you friendly joy.## World peace is coolLet's bake some cakes and be nice to each other
Get a header value
;// Returns "World peace is cool"value;
Change a header
;// Return a new markdown string where the first header// is "Stuff that's cool"// gets the first heading!;;
Change an entire paragraph
;// Change the "dogs" header and return a new markdown string// Get the first sub header;
Status
Mark-dom is really just an experiment at the moment and I haven't really fleshed out all of the API that I want yet. Things might change, at the time that I'm writing this, I don't think it even works.
TODO list
- ~Glob syntax
*
~ - Find tables
- Find code
- Find lists
- Putting a 2d array in
set()
will create a table - Putting a 1d array in
set()
will create a list
How's it work?
Mark-dom uses remark and it's ecosystem to parse the markdown into an Abstract Syntax Tree (AST), then it lets you navigate and edit the tree with an API and eventually construct a new markdown document by compiling the tree down to a string.
What's the use case?
- Auto-generating README's
- Forcing standards/style-guides to docs
- ???
- Profit!