让 Markdown 中的代码可以实时运行

2018-08-28 17:18:37 +08:00
 simonguo

背景

让 Markdown 中的代码可以实时运行,为什么会有这样一个需求?

在我们前端团队中,技术相关的文档都采用 Markdown 编写, 文档中往往会伴随很多示例代码,我们希望大家在阅读文档的时候,可以运行示例代码,看到效果。

需求

明确需求以后,写了一个 React 组件来满足这些功能, react-code-view , 首先看一下效果:

在线预览: https://simonguo.github.io/react-code-view/

原理

安装

npm install react-code-view

配置 webpack

在 webpack 中需要添加对 markdown-loader 的支持。 需要安装:

npm install html-loader --save-dev
npm install markdown-loader --save-dev
npm install react-markdown-reader --save-dev

webpack.config.js 配置

>=webpack 2.x +


const markdownRenderer = require('react-markdown-reader').renderer;

{
  test: /\.md$/,
  use: [{
    loader: 'html-loader'
  }, {
    loader: 'markdown-loader',
    options: {
      pedantic: true,
      renderer: markdownRenderer(/**languages:Array<string>**/)
    }
  }]
}

languages 默认值:["javascript", "bash", "xml", "css", "markdown", "less"];

Github: https://github.com/simonguo/react-markdown-reader

添加 Babel

示例代码中通常是使用到 ES2015+ , React 等,需要对代码实时做编译,所以在 html 中引入 babel :

<script type="text/javascript" src="//cdn.staticfile.org/babel-standalone/6.24.0/babel.min.js"></script>

示例


import CodeView from 'react-code-view';
import '~react-code-view/lib/less/index.less';

import { Button } from 'rsuite';


<CodeView dependencies={{ Button }} >
  {require('./example.md')}
</CodeView>

源代码都统一写在 markdown 中,参考: example.md

这里需要注意的是把需要运行的代码一定要放在 <!--start-code--><!--end-code--> 之间。

谁在用?

3424 次点击
所在节点    程序员
14 条回复
XiaoXiaoNiWa
2018-08-28 17:21:20 +08:00
这个不错…
litpen
2018-08-28 18:04:38 +08:00
mark
dlsflh
2018-08-28 18:14:21 +08:00
Juypter Notebook 不好吗?
wph95
2018-08-28 20:25:59 +08:00
一种可实时修改的 https://github.com/mdx-js/mdx 的感觉
Doragd
2018-08-28 22:18:56 +08:00
@dlsflh 看到题目,我也直接就想到了 Jupyter
szetrov
2018-08-28 22:56:41 +08:00
Juypter + 1,可能因为 Juypter 支持的语言少?
szetrov
2018-08-28 22:57:35 +08:00
@szetrovJuypter-> Jupyter..... mac 输入法直接更正了没反应过来
strugglexiang
2018-08-28 23:07:15 +08:00
chuhemiao
2018-08-28 23:45:49 +08:00
vue 配置用 markdown-loader 解析 md 语法,排版显示有问题(基本纯输出,没有换行和适配),老哥知道是啥问题吗
metrxqin
2018-08-29 09:07:44 +08:00
为什么不试试 http://jsfiddle.net 呢?
metrxqin
2018-08-29 09:09:46 +08:00
我不确定你们文档怎么组织的,但 Highcharts API 文档示例是这样写的。
simonguo
2018-08-29 12:39:19 +08:00
@chuhemiao 排版显示问题是 css 解决的。
simonguo
2018-08-29 12:43:02 +08:00
@metrxqin 这样做的目的是维护起来会非常方便,比如这样一个文件: https://github.com/rsuite/rsuite.github.io/blob/master/src/components/button/appearance.md

如果有人提 PR 的话也很方便。
maggiefor
2018-08-29 15:08:03 +08:00
mark

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/484020

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX