vue中利用simplemde实现markdown编辑器(增加图片上传功能)


Posted in Javascript onApril 29, 2019

前言

最近在搭个人博客网站,需要一个 markdown 编辑器,来进行博客的编写

看了网上的教程,决定使用 simplemde

以为可以直接能拿来用的

不过实际运用的时候发现还是有要完善的地方

比如令人头疼的图片上传

最终效果

 vue中利用simplemde实现markdown编辑器(增加图片上传功能)

安装及初始化

npm install simplemde --save

在html中加入一个textarea

<textarea id="simplemde"></textarea>

在vue的生命周期函数 mounted 中,添加 simplemde 的实例化

var simplemde = new SimpleMDE({
   el: document.getElementById(simplemde)
  })

el 通过dom指定为我们建立的textarea元素,如果省略,则会自动抓取html结构中的第一个textarea

绑定事件,使我们的内容数据始终与 simplemde 获取到的键入数据同步

simplemde.codemirror.on("change", () => {
   this.content = simplemde.value()
  })

上传图片

在原本的 simplemde 中

点击图片按钮的效果是这样的

vue中利用simplemde实现markdown编辑器(增加图片上传功能)

这是个啥??本地上传的选择框呢??

没办法,既然没有就只好自己做一个了

首先我们建立一个隐藏的 input

<input style="display:none" accept="image/gif,image/jpeg,image/jpg,image/png" type="file" id="upInput" ref="upInput">

接收图片格式的文件,点击即可弹出本地上传的文件选择框

之所以要隐藏,是因为我们并不想要这个按钮

我们还是想通过点击 simplemde 的图片按钮来上传

虽然人家没啥用,但好看呀

所以我们就把这个 input 给隐藏,只用一下它的 click 方法

这样我们点击图片按钮就相当于在点击这个 input

在 simplemde 的源码里,找到图片按钮调用的函数

把原来的都注释掉,加上这两句

vue中利用simplemde实现markdown编辑器(增加图片上传功能)

这样我们就可以调用本地上传的选择框了

vue中利用simplemde实现markdown编辑器(增加图片上传功能)

那么选择了图片之后,为了能即时预览

我们希望选择之后,就发到后端存储起来

在前端我们运用 axios + formdata 进行发送

var input = this.$refs.upInput
var formData = new FormData()
formData.append("i", input.files[0])
var config = {
   headers: {
    "Content-Type": "multipart/form-data"
   }
  }
this.$axios.post("/data/myupload", formData, config)

后端我是用的 node ,运用 multer 模块来接收

multer 是专门用来处理 mulipart/form-data 格式的数据的

var multer = require('multer')
    //定义存储器
  var storage = multer.diskStorage({
  //存储路径
  destination: function (req, file, cb) {
    cb(null, '../static/upload/')
  },
  //存储文件名
  filename: function (req, file, cb) {
    cb(null, `${Date.now()}-${file.originalname}`)
  }
  })
  //运用存储器
  var upload = multer({ storage: storage })

  // 接受单图的上传
  router.post('/data/myupload', upload.single('i'), function (req,  res, next) {
  //将存储后的文件名发还给前端
  res.send(req.file.filename)
  });

前端收到文件名后,将其跟存储路径打包写进文本框中

也就是之前点击图片按钮看到的那串字符

写入后就可预览

this.$axios.post("/data/myupload", formData, config).then((res)=> {
  var urlname=`![](/static/upload/${res.data})`
  simplemde.value(`${this.content}\n${urlname}\n`)
 })

看起来万事大吉了

但其实还漏了一点

那就是input的click()本身不是异步的,但是你选择图片需要时间,在这过程中后面的代码(即便是异步代码)都执行了一遍,也就是说现在写的这些发送存储都在选完图片之前就执行完了

为了在选择完图片之后再执行

我们新增一个监听事件,监听 input 的 change ,把之前的代码都丢到这里面来

var input = this.$refs.upInput
input.addEventListener("change", () => {
 var formData = new FormData()
 formData.append("i", input.files[0])
 var config = {
  headers: {
   "Content-Type": "multipart/form-data"
  }
 }
 this.$axios.post("/data/myupload", formData, config).then((res)=> {
  var urlname=`![](/static/upload/${res.data})`
  simplemde.value(`${this.content}\n${urlname}\n`)
 })
})

这样就实现了我们的图片上传效果

显示

比如通过编辑器,我们写了一篇博客,并存储进了后台

想在别的组件中把它调出来显示

也就是字符串转为html

只需要调用 simplemde 的原型链方法

this.contentMarkdown = SimpleMDE.prototype.markdown(content)

然后把数据放到v-html中

<div v-html="contentMarkdown"></div>

即可显示

再看一遍最终效果

vue中利用simplemde实现markdown编辑器(增加图片上传功能)

PS

还有一些可以完善的地方

比如直接拖拽图片进来,或者粘贴

后期有时间研究一下再加上

总结

以上所述是小编给大家介绍的vue中利用simplemde实现markdown编辑器(增加图片上传功能),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
EasyUI中的tree用法介绍
Nov 01 Javascript
情人节之礼 js项链效果
Feb 13 Javascript
JavaScript操作XML 使用百度RSS作为新闻源示例
Feb 17 Javascript
用js调用迅雷下载代码的二种方法
Apr 15 Javascript
举例详解AngularJS中ngShow和ngHide的使用方法
Jun 19 Javascript
详解Vue + Vuex 如何使用 vm.$nextTick
Nov 20 Javascript
JavaScript复制内容到剪贴板的两种常用方法
Feb 27 Javascript
vue 解决addRoutes动态添加路由后刷新失效问题
Jul 02 Javascript
vue项目中使用lib-flexible解决移动端适配的问题解决
Aug 23 Javascript
mpvue+vuex搭建小程序详细教程(完整步骤)
Sep 30 Javascript
微信小程序如何使用canvas二维码保存至手机相册
Jul 15 Javascript
JS实现的进制转换,浮点数相加,数字判断操作示例
Nov 09 Javascript
微信小程序调用微信支付接口的实现方法
Apr 29 #Javascript
vue实现微信分享链接添加动态参数的方法
Apr 29 #Javascript
VueJs里利用CryptoJs实现加密及解密的方法示例
Apr 29 #Javascript
微信小程序地图导航功能实现完整源代码附效果图(推荐)
Apr 28 #Javascript
详解vue 路由跳转四种方式 (带参数)
Apr 28 #Javascript
使用vue完成微信公众号网页小记(推荐)
Apr 28 #Javascript
详解VUE项目中安装和使用vant组件
Apr 28 #Javascript
You might like
自定义PHP分页函数
2006/10/09 PHP
利用yahoo汇率接口实现实时汇率转换示例 汇率转换器
2014/01/14 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十六)
2014/06/30 PHP
PHP图片处理之使用imagecopyresampled函数实现图片缩放例子
2014/11/19 PHP
CI框架中$this-&gt;load-&gt;library()用法分析
2016/05/18 PHP
PHP 闭包详解及实例代码
2016/09/28 PHP
一直复略了的一个问题,关于表单重复提交
2007/02/15 Javascript
JavaScript 布尔操作符解析  &amp;&amp; || !
2012/08/10 Javascript
JQuery+DIV自定义滚动条样式的具体实现
2013/06/25 Javascript
JavaScript实现的encode64加密算法实例分析
2015/04/15 Javascript
Jquery使用val方法读写value值
2015/05/18 Javascript
JavaScript实现自动对页面上敏感词进行屏蔽的方法
2015/07/27 Javascript
js操作cookie保存浏览记录的方法
2015/12/25 Javascript
JavaScript实现给定时间相加天数的方法
2016/01/25 Javascript
基于JS实现省市联动效果代码分享
2016/06/06 Javascript
微信小程序之圆形进度条实现思路
2018/02/22 Javascript
JavaScript中的一些实用小技巧总结
2019/04/07 Javascript
细说Vue组件的服务器端渲染的过程
2019/05/30 Javascript
VUE table表格动态添加一列数据,新增的这些数据不可以编辑(v-model绑定的数据不能实时更新)
2020/04/03 Javascript
[48:20]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
Python实现在Linux系统下更改当前进程运行用户
2015/02/04 Python
按日期打印Python的Tornado框架中的日志的方法
2015/05/02 Python
Python模拟三级菜单效果
2017/09/11 Python
Python序列循环移位的3种方法推荐
2018/04/09 Python
Python3网络爬虫开发实战之极验滑动验证码的识别
2019/08/02 Python
PyTorch 普通卷积和空洞卷积实例
2020/01/07 Python
tensorflow入门:TFRecordDataset变长数据的batch读取详解
2020/01/20 Python
python实现梯度法 python最速下降法
2020/03/24 Python
python3中sys.argv的实例用法
2020/04/24 Python
pandas.DataFrame.drop_duplicates 用法介绍
2020/07/06 Python
canvas因为图片资源不在同一域名下而导致的跨域污染画布的解决办法
2019/01/18 HTML / CSS
欧迪办公美国官网:Office Depot
2016/08/22 全球购物
生产部经理岗位职责
2013/12/16 职场文书
好家长事迹材料
2014/01/23 职场文书
客运企业隐患排查工作方案
2014/06/06 职场文书
Windows 64位 安装 mysql 8.0.28 图文教程
2022/04/19 MySQL