Markdown插件mavon-editor上传图片

最终效果

在这里插入图片描述

实现方法

这里只着重说明mavon-editor如何上传图片,其他更多配置可参考文档:mavon-editor文档

<mavon-editor
      ref="mdedit"
      class="editBox"
      :ishljs="true"
      :codeStyle="code_style"
      :externalLink="externalLink"
      @imgAdd="imgAdd"
      v-model="blogContent.content"
    ></mavon-editor>

上面代码中只需关注ref属性和@imgAdd事件,其他与上传图片功能无关。下面看一下imgAdd事件的实现:

imgAdd(pos,file){
  let imgData = new FormData();
  imgData.append('file',file);
  blogApi.uploadImage(imgData).then(res=>{
    console.log(res.data.data);
    console.log(this.$refs.mdedit)
    this.$refs.mdedit.$img2Url(pos,res.data.data)
  });
}
  • pos: 写在md中的文件名
  • file: 图片文件
    然后通过form提交到服务端到上传接口,该接口会返回一个对应上传图片的链接,然后通过refs拿到mavon-editor的实例,通过它的$img2Url方法将md中文件名为pos的这个图片路径替换为服务端返回后的链接。

服务端接口

@PostMapping("/uploadImage")
public Rs uploadImage(MultipartFile file) throws IOException {
    File saveFile = new File(uploadPath);
    if(!saveFile.exists()) {
        saveFile.mkdir();
    }
    String dateTime = TimeUtil.getDate();
    String uuid = UUID.randomUUID().toString();
    String saveName = dateTime+"-"+uuid+"-"+file.getOriginalFilename();
    String savePathName = uploadPath+saveName;
    File result = new File(savePathName);
    file.transferTo(result);
    String viewUrl = uploadUrl+saveName;
    return RsUtil.success(viewUrl,"上传成功");

}

mavon-editor还有一个事件是imgDel它是在删除图片文件后回调。可以根据自己的需求考虑是否实现该函数。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@胡海龙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值