MVC markdown


前言

想在近段时间通过mvc开发个人博客,编辑器希望是markdown风格的,这样写文字会很方便。首先先解决在.net下markdown编辑器的实现,查了许多资料,有许多开源的markdown解析引擎,我暂且用的是在Nuget排名较高的Markdowndeep来解析,语法非常简单,几句代码轻松解析。

PS:接下来若出现mdd即代表MarkdownDeep

安装

在Nuget中通过Install-Package MarkdownDeep.Full命令来安装完整版的Markdowndeep

或者通过Install-Package MarkdownDeep.NET命令来安装

解析

安装完成后在Script文件中会加入几个mdd的包

MVC开发Markdown编辑器(1)-LMLPHP

MarkdownDeepLib.min.js是用来解析的,mdd_styles.css是默认的一些样式,通过js解析需要引入MarkdownDeepLib.min.js,css则可有可无

  1. js解析mdd

    1. var markdown = new MarkdownDeep.Markdown();
    2. md.ExtraMode = true;
    3. md.SafeMode = true;
    4. md.MarkdownInHtml = true;
    5. var output = md.Transform(content);
  2. .net解析mdd

    1. public static class MarkdownHelper
    2. {
    3. /// <summary>
    4. /// 生成一个私有静态实例
    5. /// </summary>
    6. private static Markdown markdown = new Markdown();
    7. /// <summary>
    8. /// 解析成Html并返回.
    9. /// </summary>
    10. /// <param name="helper">该方法扩展自HtmlHelper</param>
    11. /// <param name="text">需要被解析的字符串</param>
    12. /// <returns>The HTML representation of the supplied Markdown.</returns>
    13. public static IHtmlString Markdown(this HtmlHelper helper, string text)
    14. {
    15. // 通过Tranform方法解析字符串
    16. string html = markdown.Transform(text);
    17. markdown.ExtraMode = true;
    18. markdown.SafeMode = true;
    19. markdown.MarkdownInHtml = true;
    20. // 返回MvcHtmlString,防止被编码
    21. return new MvcHtmlString(html);
    22. }
    23. }

结束语

已经2点多了,实时预览放在下一次了。睡觉

PS:如果有哪些写的不对或不好的地方欢迎大家指点

04-25 19:44