SpringBoot使用Editor.md构建Markdown富文本编辑器


声明:本文转载自https://my.oschina.net/merryyou/blog/1635594,转载目的在于传递更多信息,仅供学习交流之用。如有侵权行为,请联系我,我会及时删除。

Markdown是一种可以使用普通文本编辑器编写的标记语言,通过简单的标记语法,它可以使普通文本内容具有一定的格式。

前言

Editor.md 是一款开源的、可嵌入的 Markdown 在线编辑器(组件),基于 CodeMirror、jQuery 和 Marked 构建。本章将使用SpringBoot整合Editor.md构建Markdown编辑器。

下载插件

项目地址:Editor.md

解压目录结构: https://raw.githubusercontent.com/longfeizheng/longfeizheng.github.io/master/images/springboot/springboot03.png

配置Editor.md

将exapmles文件夹中的simple.html放置到项目中,并配置对应的css和js文件

配置编辑器

...... 	<script src="${re.contextPath}/jquery.min.js"></script>     <script src="${re.contextPath}/editor/editormd.min.js"></script>     <link rel="stylesheet" href="${re.contextPath}/editor/css/style.css"/>     <link rel="stylesheet" href="${re.contextPath}/editor/css/editormd.css"/>     <link rel="shortcut icon" href="https://pandao.github.io/editor.md/favicon.ico" type="image/x-icon"/> ...... <!-- 存放源文件用于编辑 -->  <textarea style="display:none;" id="textContent" name="textContent"> </textarea>         <!-- 第二个隐藏文本域,用来构造生成的HTML代码,方便表单POST提交,这里的name可以任意取,后台接受时以这个name键为准 -->         <textarea id="text" class="editormd-html-textarea" name="text"></textarea>     </div> 

初始化编辑器

var testEditor;      $(function () {         testEditor = editormd("test-editormd", {             width: "90%",             height: 640,             syncScrolling: "single",             path: "${re.contextPath}/editor/lib/",             imageUpload: true,             imageFormats: ["jpg", "jpeg", "gif", "png", "bmp", "webp"],             imageUploadURL: "/file",             //这个配置在simple.html中并没有,但是为了能够提交表单,使用这个配置可以让构造出来的HTML代码直接在第二个隐藏的textarea域中,方便post提交表单。             saveHTMLToTextarea: true             // previewTheme : "dark"         });     }); 

这样就实现了最简单的editor.md编辑器,效果如下:

https://raw.githubusercontent.com/longfeizheng/longfeizheng.github.io/master/images/springboot/springboot05.png

图片上传

由于在初始化编辑器中配置的图片上传地址为imageUploadURL: "/file",,与之对应,我们在/file处理文件上传即可

@RestController @RequestMapping("/file") @Slf4j public class FileController {  //    @Value("") //    String folder = System.getProperty("user.dir")+File.separator+"upload"+File.separator;     /**      * 在配置文件中配置的文件保存路径      */     @Value("${img.location}")     private String folder;      @PostMapping     public FileInfo upload(HttpServletRequest request, @RequestParam(value = "editormd-image-file", required = false) MultipartFile file) throws Exception {         log.info("【FileController】 fileName={},fileOrginNmae={},fileSize={}", file.getName(), file.getOriginalFilename(), file.getSize());         log.info(request.getContextPath());         String fileName = file.getOriginalFilename();         String suffix = fileName.substring(fileName.lastIndexOf(".") + 1);         String newFileName = new Date().getTime() + "." + suffix;          File localFile = new File(folder, newFileName);         file.transferTo(localFile);         log.info(localFile.getAbsolutePath());         return new FileInfo(1, "上传成功", request.getRequestURL().substring(0,request.getRequestURL().lastIndexOf("/"))+"/upload/"+newFileName);     }      @GetMapping("/{id}")     public void downLoad(@PathVariable String id, HttpServletRequest request, HttpServletResponse response) {         try (InputStream inputStream = new FileInputStream(new File(folder, id + ".txt"));              OutputStream outputStream = response.getOutputStream();) {             response.setContentType("application/x-download");             response.setHeader("Content-Disposition", "attachment;filename=test.txt");              IOUtils.copy(inputStream, outputStream);             outputStream.flush();         } catch (Exception e) {          }     } }  

文件预览

表单POST提交时,editor.md将我们的markdown语法文档翻译成了HTML语言,并将html字符串提交给了我们的后台,后台将这些HTML字符串持久化到数据库中。具体在页面显示做法如下:

<!DOCTYPE html> <html lang="zh"> <head>     <meta charset="utf-8"/>     <title>Editor.md examples</title>     <link rel="stylesheet" href="${re.contextPath}/editor/css/editormd.preview.min.css" />     <link rel="stylesheet" href="${re.contextPath}/editor/css/editormd.css"/> </head> <body> <!-- 因为我们使用了dark主题,所以在容器div上加上dark的主题类,实现我们自定义的代码样式 --> <div class="content editormd-preview-theme" id="content">${editor.content!''}</div> <script src="${re.contextPath}/jquery.min.js"></script> <script src="${re.contextPath}/editor/lib/marked.min.js"></script> <script src="${re.contextPath}/editor/lib/prettify.min.js"></script> <script src="${re.contextPath}/editor/editormd.min.js"></script> <script type="text/javascript">     editormd.markdownToHTML("content"); </script> </body> </html> 

代码下载

从我的 github 中下载,https://github.com/longfeizheng/editor-markdown


https://raw.githubusercontent.com/longfeizheng/longfeizheng.github.io/master/images/wechat/xiaochengxu.png

本文发表于2018年03月16日 22:38
(c)注:本文转载自https://my.oschina.net/merryyou/blog/1635594,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如有侵权行为,请联系我们,我们会及时删除.

阅读 10735 讨论 141 喜欢 2

抢先体验

扫码体验
趣味小程序
文字表情生成器

闪念胶囊

你要过得好哇,这样我才能恨你啊,你要是过得不好,我都不知道该恨你还是拥抱你啊。

直抵黄龙府,与诸君痛饮尔。

那时陪伴我的人啊,你们如今在何方。

不出意外的话,我们再也不会见了,祝你前程似锦。

这世界真好,吃野东西也要留出这条命来看看

快捷链接
网站地图
提交友链
Contact
京ICP备2021004668号-1

相关内容推荐

美丽图片收录星空收录网图书的收录女生心事收录ei停止收录aomatt收录美图收录册知网收录中与知网收录typecho网站收录电话收录收录网站模版入口决定收录环境声音收录传记收录搜狗极速收录查询域名收录无根树收录收录书籍名新站收录展示知网收录文献时间收录年限新闻 收录 网页aapm sci收录istb收录检索.ltd域名收录网站收录消失国外收录拍摄声音收录国家收录曲笑脸收录平台全球音乐收录画作收录拿破仑骑马收录鲁迅伤逝收录blogs主题收录橘子壁纸收录收录至13.08.04谷歌收录图片精选音乐收录360收录高bloom专辑收录老舍 课本收录sci 全文收录民间收录收录期刊排名鬼魂台词收录上译收录高冷收录话题收录官pnas收录类型wordpress收录主题琳琅精品收录代收录排名混凝土 收录街霸人物收录典藏收录家scie收录范围百度快照和收录收录科目三收录fate收录曲论文收录情况有知网收录么新闻平台收录说谎 收录企业引擎收录天空收录手册邓丽君金曲收录网线收录信息收录策略收录类型查询轨迹未收录收录金鱼springerlink收录情况百度首页不收录内页收录新号未收录神雕侠侣收录域名收录快谷歌收录翻译港产收录剧ei收录与不收录的区别收录时限收录引流bbs收录排名GAI收录教材周记收录大佑收录北图收录期刊知名网站收录杂志被sci收录但文章不收录头像收录集收录如家网上收录检索伤逝》收录天星收录新年寄语收录古诗收录网址收录天星华为声音收录职称 论文 收录星球单卡收录wayv收录曲快速收录上酷润快速收录账号未被收录ca收录杂志和ca收录文章收录链接查询女神收录华夏地理收录lemon网站收录双收录网站被WOSCC收录pci收录春日狂想收录快递号收录万方收录知网没有收录知网收录和万方收录头条收录和百度收录bbs 不收录新闻源收录和网页收录区别橙色收录银行收录条数百度普通收录多久收录lof快照收录站长快速收录被收录页面不想再被收录收录胶装enduro收录日落繁星收录收录索引名和收录号怎么查霍金语言收录收录系统简介360收录负面头条收录统计新年寄语收录如何鉴别EI收录还是EI会议收录seo 网站收录收录标题公式myself收录网站内页收录了首页没收录githubpages收录名言警句收录结局收录1.3.1戒指收录兑换码收录nardack画集收录网站收录宝Inspecs收录森林派对收录收录查询接口《彷徨》收录girls歌曲收录scsd 收录药典收录中药收录中心网站收录免费期刊 收录eiistp收录上译收录收录宣传收录快照笔记收录低收录新年祝福百度收录只收录首页快递收录任务行情收录工具收录论文数api收录savag收录曲论文收录格式php收录drupal收录收录政治故事谷歌收录比百度收录好百度PC收录移动没收录产品页面收录bts专辑收录没收录的网站怎么快速收录avzou收录想要网站收录商业文化收录美食收录手册知识收录网站收录了cazy收录不全四网收录和三网收录博客怎样收录socolar收录花的收录ajax收录收录的文献目录收录站esi收录 scimedline收录时间法规收录信息收录系统medline 收录 容易未收录概率临海网站收录新书收录新浪博客被收录的又没收录未收录文章滑板收录杂志社发收录 知网收录

合作伙伴

凤巢SEO

niu.seo5951.com
jl.urkeji.com
www.chaoshanxing.com
www.imcrd.com
qiansan.seo5951.com
www.kapauw.com
niu.seo5951.com
www.kmpower.cn
www.desai360.com
www.bjdongwei.cn
www.kapauw.com
www.xm5656.cn
seo.china185.com
kuai.urkeji.com
www.urkeji.com
www.wangluohr.cn
jl.urkeji.com
www.xtcwl.com
seo.07yue.com
www.te3.com.cn