如何让simplemde Markdown编辑器支持图片上传功能?

2026-04-09 14:371阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1766个文字,预计阅读时间需要8分钟。

如何让simplemde Markdown编辑器支持图片上传功能?

前言:最近在搭建个人博客网站,需要一个Markdown编辑器来进行博客的编写。看了网上的教程后,决定使用simplemde作为编辑器,因为它可以直接使用且运行稳定。以下是一些关于simplemde的发现和优化建议。

simplemde简介:simplemde是一个轻量级的Markdown编辑器,它支持实时预览和代码高亮等功能。由于其简洁易用,非常适合个人博客网站。

安装simplemde:首先,需要在项目中引入simplemde的相关文件。可以通过以下步骤进行:

1. 在项目根目录下创建一个名为`vendor`的文件夹。

2.在`vendor`文件夹中创建一个名为`simplemde`的文件夹。

3.将simplemde的源码文件(包括`simplemde.min.js`和`simplemde.min.css`)复制到`simplemde`文件夹中。

4.在HTML文件中引入simplemde的CSS和JavaScript文件。

使用simplemde:在HTML文件中创建一个用于显示编辑器内容的容器,并使用以下JavaScript代码初始化simplemde编辑器:

javascriptvar simplemde=new SimpleMDE({ element: document.getElementById(editor), previewStyle: markdown, spellChecker: false});

优化建议:

1.个性化设置:simplemde提供了丰富的配置选项,可以根据自己的需求进行个性化设置,例如字体大小、颜色主题等。

2.插件扩展:simplemde支持插件扩展,可以通过添加插件来增强编辑器的功能,例如插入表格、图片等。

3.文件存储:可以将编辑器的内容保存到本地存储或服务器,方便用户随时查看和修改。

总结:

simplemde是一个简单易用的Markdown编辑器,适合个人博客网站。通过配置和扩展,可以提高编辑器的实用性和易用性。在使用过程中,要注意发现和解决可能出现的问题,不断完善编辑器。

前言

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

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

以为可以直接能拿来用的

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

比如令人头疼的图片上传

最终效果

安装及初始化

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 中

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


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

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

首先我们建立一个隐藏的 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 的源码里,找到图片按钮调用的函数

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


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


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

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

在前端我们运用 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 模块来接收

如何让simplemde Markdown编辑器支持图片上传功能?

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>

即可显示

再看一遍最终效果

PS

还有一些可以完善的地方

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

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

总结

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

本文共计1766个文字,预计阅读时间需要8分钟。

如何让simplemde Markdown编辑器支持图片上传功能?

前言:最近在搭建个人博客网站,需要一个Markdown编辑器来进行博客的编写。看了网上的教程后,决定使用simplemde作为编辑器,因为它可以直接使用且运行稳定。以下是一些关于simplemde的发现和优化建议。

simplemde简介:simplemde是一个轻量级的Markdown编辑器,它支持实时预览和代码高亮等功能。由于其简洁易用,非常适合个人博客网站。

安装simplemde:首先,需要在项目中引入simplemde的相关文件。可以通过以下步骤进行:

1. 在项目根目录下创建一个名为`vendor`的文件夹。

2.在`vendor`文件夹中创建一个名为`simplemde`的文件夹。

3.将simplemde的源码文件(包括`simplemde.min.js`和`simplemde.min.css`)复制到`simplemde`文件夹中。

4.在HTML文件中引入simplemde的CSS和JavaScript文件。

使用simplemde:在HTML文件中创建一个用于显示编辑器内容的容器,并使用以下JavaScript代码初始化simplemde编辑器:

javascriptvar simplemde=new SimpleMDE({ element: document.getElementById(editor), previewStyle: markdown, spellChecker: false});

优化建议:

1.个性化设置:simplemde提供了丰富的配置选项,可以根据自己的需求进行个性化设置,例如字体大小、颜色主题等。

2.插件扩展:simplemde支持插件扩展,可以通过添加插件来增强编辑器的功能,例如插入表格、图片等。

3.文件存储:可以将编辑器的内容保存到本地存储或服务器,方便用户随时查看和修改。

总结:

simplemde是一个简单易用的Markdown编辑器,适合个人博客网站。通过配置和扩展,可以提高编辑器的实用性和易用性。在使用过程中,要注意发现和解决可能出现的问题,不断完善编辑器。

前言

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

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

以为可以直接能拿来用的

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

比如令人头疼的图片上传

最终效果

安装及初始化

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 中

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


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

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

首先我们建立一个隐藏的 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 的源码里,找到图片按钮调用的函数

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


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


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

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

在前端我们运用 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 模块来接收

如何让simplemde Markdown编辑器支持图片上传功能?

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>

即可显示

再看一遍最终效果

PS

还有一些可以完善的地方

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

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

总结

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