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

2020-06-16 06:39:53易采站长站整理

在前端我们运用 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)