javascript - Node.js - 如何读取/写入更改其前端元数据的 Markdown 文件?

标签 javascript node.js markdown

我有几百个 Markdown 文件,我想遍历它们并将新数据添加到它们的前端元数据中。
例如,这就是我的文件现在的样子:

---
title: My title here
---


Markdown content here
我想添加一个 编号 属性(property)给他们:
---
title: My title here
id: 1982n1x23981u1
---


Markdown content
在 Node 中最干净的方法是什么?我找到了一些处理 Markdown 的包,但它们都旨在将其转换为 JSON。
提前致谢!

最佳答案

这是我用来更新 Markdown 脚本中所有笔记的前端的基本脚本:

// @ts-check
const { readdir, readFile, writeFile } = require("fs/promises");
const matter = require("gray-matter");
const { stringify } = require("yaml");

const directory = "<YOUR-DIRECTORY>";

async function updateFrontMatter(filename) {
  const filepath = `${directory}/${filename}`;

  const { data: frontMatter, content } = matter(await readFile(filepath));

  // remove desc attribute
  if (frontMatter.desc === "") {
    delete frontMatter["desc"];
  }

  // parse created date attribute and convert it as timestamp
  if (typeof frontMatter.created === "string") {
    frontMatter.created = new Date(frontMatter.created).getTime();
  }

  const newContent = `---\n${stringify(frontMatter)}---\n${content}`;

  await writeFile(filepath, newContent);

  console.log(`- [x] ${filepath}`);
}

async function main() {
  const filenames = await readdir(directory);
  const markdownFilenames = filenames.filter((f) => f.endsWith(".md"));

  await Promise.all(markdownFilenames.map(updateFrontMatter));
}

main().catch(console.error);

关于javascript - Node.js - 如何读取/写入更改其前端元数据的 Markdown 文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62586022/

相关文章:

javascript - 使用 Web API 的纯前端 JavaScript 与使用 ajax 的 MVC View

javascript - knockout 多个 View 模型 - 未定义

javascript - XMLHttpRequest.upload.onprogress 不适用于 HTTPS

r - .rmd 和 .Rmd 文件之间有区别吗?

css - 在 ipython 笔记本中设置单个 Markdown 单元格的样式

javascript - .net mvc 5 不引人注目的禁用字段验证

javascript - 如何在 octobercms 中使用 ajax 或 javascript 动态更改表单的方向

javascript - 将响应消息从一个客户端发送到另一个 socket.io 时出现问题

javascript - jQuery 验证在 Bootstrap 模式中不起作用

markdown - 使用 Markdown [POSTACH.IO] 制作 "Read More"发布链接