《Editor.md文档书写神器-笔录》

简介

Editor.md是编辑书写Markdown的插件。可以帮助我们书写出漂亮的Markdown文档。
下面我介绍使用Editor.md插件,集成到web前端。功能点:

  • 1.实现markdown文档编辑器
  • 2.实现markdown文档查看器
    使用markdown文档编辑器书写完文档后保存到服务器,然后通过markdown文档查看器去请求服务器获取到之前保存的*.md文档进行浏览查看。掌握了它我们就可以自己去扩展属于自己的文档编辑工具甚至平台。

实现步骤:

建议先到官方看下如何使用,避免少走弯路
官方地址 https://pandao.github.io/editor.md/examples/index.html

  • 2.集成到项目中
    下载下来解压后是一个npm项目,你可以直接使用 也可以自行再扩展功能,下载依赖modules,再编译构建。这里 我就不重新构建了,需要重新构建的同学如果不清楚如何构建npm项目可以参考我的其它文章《NodeJS开发教程5-包管理工具npm》https://www.jianshu.com/p/445d0168d691
    image.png

好,接下来我们把下载的Editor.md插件copy到我们的项目,只copy我们用到的文件也可以,或者干脆暴力一点把所有文件都copy到项目(发布版建议去除非依赖文件)我把它copy到了项目的前端插件目录中(并且我重新命了下文件夹的名称:editor.md):

image.png
  • 3.实现markdown文档编辑器
    我在项目的前端目录中创建了 md-editor.html 用来实现markdown文档编辑器:
image.png

md-editor.html文件内容:

<!DOCTYPE html>
<html lang="zh">
    <head>
        <meta charset="utf-8" />
        <title>Editor.md-Markdown编辑器</title>
        <link rel="stylesheet" href="../plugins/editor.md/examples/css/style.css" />
        <link rel="stylesheet" href="../plugins/bootstrap/dist/css/bootstrap.css" />
        <link rel="stylesheet" href="../plugins/editor.md/css/editormd.css" />

    </head>
    <body>
        <div id="layout">
            <header>
                <h1 style="text-align: center;">Editor.md-Markdown编辑器</h1>
            </header>
            <div style="width: 90%;margin: auto;">
                <button style="margin: 1rem;" class="btn btn-success pull-right" type="button" onclick="saveDoc()">保存文档</button>
            </div>
            <div id="test-editormd">
                <textarea style="display:none;">

[TOC]

#MD文档编辑器(爽)

#### 可以显示列表项

- TeX (Based on KaTeX);
- Emoji;
- Task lists;
- HTML tags decode;
- Flowchart and Sequence Diagram;

#### 可以显示目录 directory

    editor.md/
            lib/
            css/
            scss/
            tests/
            fonts/
            images/
            plugins/
            examples/
            languages/
            editormd.js
            ...
####[TOC]文档目录自动生成

头部引入 '[TOC]' 参考本文档头部,目录索引自动生成,很方便的!

</textarea>
            </div>
        </div>
        <script src="../plugins/editor.md/examples/js/jquery.min.js"></script>
        <script src="../plugins/editor.md/editormd.min.js"></script>
        <script type="text/javascript">
            var testEditor;

            $(function() {
                testEditor = editormd("test-editormd", {
                    width   : "90%",
                    height  : 640,
                    syncScrolling : "single",
                    path    : "../plugins/editor.md/lib/"
                });
                
                /*
                // or
                testEditor = editormd({
                    id      : "test-editormd",
                    width   : "90%",
                    height  : 640,
                    path    : "../plugins/editor.md/lib/"
                });
                */
            });
        </script>
    <script>
        //保存文档
        function saveDoc()
        {
            // 获取Markdown源码
            var mdstr=testEditor.getMarkdown();
            console.log(mdstr);
            //保存到服务器
            $.post("/bf/saveDoc",{filename:"test1",content:mdstr},function(data)
            {
                alert(data);
            });
        }
    </script>
    </body>
</html>

  • 4.实现服务器存储编辑器内容
    服务器我用的是springboot,当然你也可以用你熟悉的服务器来管理文档内容。
import com.yu.scloud.baseframe.frame.utils.FileOperate;
import org.springframework.util.ResourceUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.ServletRequest;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;

@RestController
public class MDWriterController {

    @RequestMapping("/saveDoc")
    public String saveDoc(String filename, String content, ServletRequest request)
    {
        try {
            File file=getFile("/static/demo/doc/");
            FileOperate.writeFile(file.getAbsolutePath()+filename+".md",content);
            return "保存成功";
        } catch (IOException e) {
            e.printStackTrace();
        }
        return "保存失败";
    }
    private File getFile(String rel) throws FileNotFoundException {
        //获取跟目录
        File path = new File(ResourceUtils.getURL("classpath:").getPath());
        return new File(path.getAbsolutePath(),rel);
    }
    @RequestMapping("/viewDoc")
    public String viewDoc(String filename)
    {
        try {
            File file=getFile("/static/demo/doc/");
            return FileOperate.readFile(file.getAbsolutePath()+filename+".md");
        } catch (IOException e) {
            e.printStackTrace();
        }
        return "";
    }
}

启动服务器访问md-editor.html,编辑好信息后就可以保存文档了:


image.png

文档会保存到你指定的服务器目录中,并命名为:*.md。我这里命名为:test1.md

  • 5.实现markdown文档查看器
    新建 view-md.html 内容如下:
<!DOCTYPE html>
<html lang="zh">
    <head>
        <meta charset="utf-8" />
        <title></title>
        <link rel="stylesheet" href="../plugins/editor.md/examples/css/style.css" />
        <link rel="stylesheet" href="../plugins/editor.md/css/editormd.preview.css" />
        <style>            
            .editormd-html-preview {
                width: 90%;
                margin: 0 auto;
            }
        </style>
    </head>
    <body>
        <div id="layout">
            <header>
                <h1>Markdown转HTML的显示处理</h1> 
                <p>即:非编辑情况下的HTML预览</p>
                <p>HTML Preview(markdown to html)</p>       
            </header>
            <div id="test-editormd-view">
               <textarea style="display:none;" name="test-editormd-markdown-doc">###Hello world!</textarea>               
            </div>
        </div>
        <!-- <script src="js/zepto.min.js"></script>
        <script>        
            var jQuery = Zepto;  // 为了避免修改flowChart.js和sequence-diagram.js的源码,所以使用Zepto.js时想支持flowChart/sequenceDiagram就得加上这一句
        </script> -->
        <script src="../plugins/editor.md/examples/js/jquery.min.js"></script>
        <script src="../plugins/editor.md/lib/marked.min.js"></script>
        <script src="../plugins/editor.md/lib/prettify.min.js"></script>
        
        <script src="../plugins/editor.md/lib/raphael.min.js"></script>
        <script src="../plugins/editor.md/lib/underscore.min.js"></script>
        <script src="../plugins/editor.md/lib/sequence-diagram.min.js"></script>
        <script src="../plugins/editor.md/lib/flowchart.min.js"></script>
        <script src="../plugins/editor.md/lib/jquery.flowchart.min.js"></script>

        <script src="../plugins/editor.md/editormd.js"></script>
        <script type="text/javascript">
            $(function() {
                var testEditormdView;
                //可以加入模板引擎或是访问query动态传入view的md文档
                $.get("/bf/viewDoc?filename=test1",function(data)
                {
                    var content=data;
                    $("#test-editormd-view textarea").text(content);
                    testEditormdView = editormd.markdownToHTML("test-editormd-view", {
                        htmlDecode      : "style,script,iframe",  // you can filter tags decode
                        emoji           : true,
                        taskList        : true,
                        tex             : true,  // 默认不解析
                        flowChart       : true,  // 默认不解析
                        sequenceDiagram : true,  // 默认不解析
                    });
                });
            });
        </script>
    </body>
</html>

指定刚刚生成的 test1.md文档资源查看:

image.png

这样我们就实现了简单的文档编辑、上传、以及查看功能,是不是很简单!END。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容

  • 如果你每日浑浑噩噩不知道自己该干什么或者干了什么,强烈建议你可以跟我聊聊,因为我除了上班,除了带娃,我还要谈代理谈...
    泽泽a阅读 178评论 0 0
  • 爱情是一件美好的事情 说爱的太容易 说不爱的太轻易 就像是在攀爬一座高山 只要你告诉我 一定可以 那么即使是珠峰 ...
    毛小诗阅读 160评论 3 3
  • MyEclipse强行关闭后重启Servers报错。 1.打开myeclipse所在的wordspace文件夹并找...
    nikiie阅读 447评论 0 0