JavaScript 如何将 HTML 转成 Markdown?

2022-08-22 09:09:48 浏览数 (1)

本篇带来:在 JavaScript 如何将 HTML 转成 Markdown?先收藏,总有一天要用到!!

npm

我们主要是借助 Turndown 这个库来实现的

npm 安装

代码语言:javascript复制
npm i turndown

es6 import 引入:

代码语言:javascript复制
import TurndownService from 'turndown'

CommonJs require 引入:

代码语言:javascript复制
const TurndownService = require('turndown');

接下来我们就可以简单的使用它了:

代码语言:javascript复制
import TurndownService from 'turndown';
const html = `
<h1>Learn Web Development</h1>
<p>Check out <a href="https://codingbeautydev.com/blog">Coding Beauty</a> for some great tutorials!</p>
`;
// Create an instance of the Turndown service
const turndownService = new TurndownService();
const markdown = turndownService.turndown(html);
console.log(markdown);

输出如下:

代码语言:javascript复制
Learn Web Development
=====================
Check out [Coding Beauty](https://codingbeautydev.com/blog) for some great tutorials!

script

除了 npm 安装的方式,我们还可以通过 <script> 标签引入的方式实现调用:

代码语言:javascript复制
<script src="https://unpkg.com/turndown/dist/turndown.js"></script>

调用实现转换:和上面例子一致

代码语言:javascript复制
const html = `
<h1>Learn Web Development</h1>
<p>Check out <a href="https://codingbeautydev.com/blog">Coding Beauty</a> for some great tutorials!</p>
`;
// Create an instance of the Turndown service
const turndownService = new TurndownService();
const markdown = turndownService.turndown(html);
console.log(markdown);

我们还可以直接对 dom 节点进行转换

代码语言:javascript复制
// convert document <body> to Markdown
const bodyMarkdown = turndownService.turndown(document.body);

参数配置

于此同时,turndown 还有一些参数可以配置:

比如 bulletListMarker 属性,可以将 markdown 中的 list 用符号作标记:

代码语言:javascript复制
import TurndownService from 'turndown';
const html = `
<ul>
<li>HTML</li>
<li>CSS</li>
<li>JavaScript<li>`;
// Specifying options when creating an instance of the
// Turndown service
const turndownService = new TurndownService({ bulletListMarker: '-' });
const markdown = turndownService.turndown(html);
console.log(markdown);

输出:

代码语言:javascript复制
-   HTML
-   CSS
-   JavaScript

更多属性配置见:https://github.com/mixmark-io/turndown

小结:JavaScript 如何将 HTML 转成 Markdown?记得用 turndown !

0 人点赞