mavon-editor 存储md文件以及md文件解析成html文件
一、md文件的存储
因为是vue-cli项目,所以使用的是mavonEditor.
github地址:https://github.com/hinesboy/mavonEditor
使用方法:
首先安装:
npm install mavon-editor --save
然后在相应的组件里引用:
//引入
import {mavonEditor} from 'mavon-editor'
import 'mavon-editor/dist/css/index.css'
//标签使用,注意这里是mavon-editor
<mavon-editor style="height: 100%;width: 100%;"
v-model="form.content"
ref="md"
defaultOpen="edit"
:toolbars="toolbarsValue"
@imgAdd="$imgAdd"
@change="changeMavon"
@save="saveMavon" />
//mavon-editor菜单栏的相关配置
toolbarsValue: {
                bold: true, // 粗体
                italic: true, // 斜体
                header: true, // 标题
                underline: true, // 下划线
                strikethrough: true, // 中划线
                mark: true, // 标记
                superscript: true, // 上角标
                subscript: true, // 下角标
                quote: true, // 引用
                ol: true, // 有序列表
                ul: true, // 无序列表
                link: true, // 链接
                imagelink: true, // 图片链接
                code: true, // code
                table: true, // 表格
                fullscreen: true, // 全屏编辑
                readmodel: true, // 沉浸式阅读
                htmlcode: true, // 展示html源码
                help: true, // 帮助
                /* 1.3.5 */
                undo: true, // 上一步
                redo: true, // 下一步
                trash: true, // 清空
                save: false, // 保存(触发events中的save事件)
                /* 1.4.2 */
                navigation: true, // 导航目录
                /* 2.1.8 */
                alignleft: true, // 左对齐
                aligncenter: true, // 居中
                alignright: true, // 右对齐
                /* 2.2.1 */
                subfield: true, // 单双栏模式
                preview: true, // 预览
            },
//相关的方法
//富文本保存的方法
saveMavon(value,render){ console.log("this is render"+render);
console.log("this is value"+value);
},
// 绑定@imgAdd event
$imgAdd(pos, $file){
console.log("触发图片上传");
console.log(pos);
console.log($file);
// 第一步.将图片上传到服务器.
var formdata = new FormData();
formdata.append('file', $file);
console.log(formdata);
imgeApi(formdata).then(res=>{
// 第二步.将返回的url替换到文本原位置 -> 
/**
* $vm 指为mavonEditor实例,可以通过如下两种方式获取
* 1. 通过引入对象获取: `import {mavonEditor} from ...` 等方式引入后,`$vm`为`mavonEditor`
* 2. 通过$refs获取: html声明ref : `<mavon-editor ref=md ></mavon-editor>,`$vm`为 `this.$refs.md`
*/
console.log(res.data);
let url="/server/"+res.data.data;
this.$refs.md.$img2Url(pos, url);
//相应的md格式的文件内容就是它绑定的变量
});
},
我选择的是直接将md格式的文本保存到数据库中,然后再将其从数据库中取出来解析。
二、md格式的文本的解析
使用marked框架来解析。
方法步骤:
npm install marked --save
在组件中引用:
相应的标签:
js方法:
//这里的newDate[0].content就是取出来的md格式的文本内容
this.readmeContent=marked(newData[0].content||'',{
sanitize:true
})
存在问题:现在纯粹的只是将其解析成了html文件,相应的样式查了下,可以用highlight.js,但折腾了好久都没引用成功,等之后再仔细看看marked的官方文档再说....
地址:https://marked.js.org/#/README.md#README.md
mavon-editor 存储md文件以及md文件解析成html文件的更多相关文章
- Excelbatis-一个将excel文件读入成实体列表、将实体列表解析成excel文件的ORM框架,简洁易于配置、可扩展性好
		
欢迎使用Excelbatis! github地址:https://github.com/log4leo/Excelbatis Excelbatis的优点 和spring天然结合,易于接入 xsd支持, ...
 - PyCharm将main.py解析成text文件的解决方法
		
问题:PyCharm将main.py解释成文本文件,没有代码提示,也无法执行 解决方法:File->Settings->Editor->File Types ->选则Text ...
 - jar包/class文件如何快速反编译成java文件
		
有时编写的java代码打包为可执行jar包后需要查看工程结构是否是且只有我们需要的包,故需要查看jar包层级. 1.windows系统可以直接在网上下载jd-gui.exe包,然后傻瓜安装: 2.Ma ...
 - 将java文件编译成class文件
		
一般情况下,在myeclipse中保存java文件后会自动编译成class文件,但是这种情况只能编译当前工程的java文件,但是如果需要编译不是一个工程的java文件,比如在网上拷贝的java文件改如 ...
 - stm32启动文件ld md hd cl vl xl分析及选择
		
startup_stm32f10x_cl.s互联型的STM32F105xx,STM32F107xxstartup_stm32f10x_hd.s 大容量的STM32F101xx,STM32F102xx, ...
 - Linux文件查找.md
		
Linux 文件查找 在Linux系统的查找相关的命令: which 查看可执行文件的位置 whereis 查看文件的位置 locate 配合数据库查看文件位置 find 实际搜寻硬盘查询文件名称 w ...
 - - Gradle 翻译 Analyzer APK文件分析 MD
		
目录 目录 APK文件分析 使用 APK 分析器分析您的编译版本 查看文件和大小信息 查看 AndroidManifest.xml 查看 DEX 文件 过滤DEX文件树视图 加载 Proguard 映 ...
 - python检测文件的MD值
		
使用hashlib模块,可对文件MD5一致性加密验证: #python 检测文件MD5值 #python version 2.6 import hashlib import os,sys #简单的测试 ...
 - 无废话Android之android下junit测试框架配置、保存文件到手机内存、android下文件访问的权限、保存文件到SD卡、获取SD卡大小、使用SharedPreferences进行数据存储、使用Pull解析器操作XML文件、android下操作sqlite数据库和事务(2)
		
1.android下junit测试框架配置 单元测试需要在手机中进行安装测试 (1).在清单文件中manifest节点下配置如下节点 <instrumentation android:name= ...
 
随机推荐
- js 异步问题
			
如果发现前端的异步请求,network有发送成功而且有返回值,但是没有进前端的callback成功回掉函数内,这时候就需要检查是不是配置文件做了语法限制,只能返回某些数据格式,不能返回某些数据格式. ...
 - CF 622 F The Sum of the k-th Powers —— 拉格朗日插值
			
题目:http://codeforces.com/contest/622/problem/F 设 f(x) = 1^k + 2^k + ... + n^k 则 f(x) - f(x-1) = x^k ...
 - SSL卸载技术对于HTTPS应用的优化与思考
			
迅猛发展的互联网为我们提供了丰富的信息资源,在带来便利的同时也影响着人们工作和生活方式.而让我们无法忽视的是,在开放的互联网所带来的繁荣背后,同时也潜藏着安全方面的隐患.随着人们对网络的依赖愈渐加深, ...
 - C++学习笔记1-使用数组进行vector初始化
			
另外,如果是定义的时候,可以直接指定复制.比如:int s[5]={1,2,3,4,5};vector<int> v(s,s+5);就可以啦.
 - JSP页面无法识别EL表达式
			
昨天一直纠结一个问题,JSP页面无法获取${user}的值,一直显示的是${user},今天解决了,原来是JSP页面无法识别EL表达式. 我的web.xml的声明如下: <!DOCTYPE we ...
 - Httpclient爬取优酷网
			
参考:http://www.cnblogs.com/lchzls/p/6277210.html /httpClient/src/main/java/com/louis/youku/Page.java ...
 - 2.3 Hive的数据类型讲解及实际项目中如何使用python脚本对数据进行ETL
			
一.hive Data Types https://cwiki. apache. org/confluence/display/HiveLanguageManual+Types Numeric Typ ...
 - mosquitto.conf之log配置
			
# ================================================================= # Logging # 日志信息 # ============= ...
 - 【eclipse插件开发实战】Eclipse插件开发7——插件发布jar包
			
Eclipse插件开发7--插件发布jar包 最省事的方式就是直接导出jar包,然后放到eclipse的plugins目录下,重启eclipse即可. step1: 对需要打包的插件工程右击→导出(E ...
 - UVa 1001 Say Cheese  (Dijkstra)
			
题意:给定一个三维空间的一些球和起始位置和结束位置,问你最短要花的时间是多少. 析:建图,所有的位置都建立图,边权就是距离,最小求一次最短路即可. 代码如下: #pragma comment(link ...