Vue如何使用Element-ui表单发送数据与多张图片到后端详解

在做项目的时候遇到一个问题,前端需要上传表单到后端,表单数据包括文本内容和图片,后端我用的是Nodejs,效果类似下图

Vue如何使用Element-ui表单发送数据与多张图片到后端详解_第1张图片

前端需要向后端传商品名称,价格,描述,商品图片

前端准备,利用Element-ui中的表单功能和上传功能,将upload代码嵌套在表单中,代码如下

需要注意的是,upload中的action传的是对应的后端接口

Vue如何使用Element-ui表单发送数据与多张图片到后端详解_第2张图片

在上传图片前,需要先将图片转成base64格式的字符串后再上传给后端,这里定义了 beforeProductUpload函数进行转码处理

 beforeProductUpload(file){
          var _this = this
        return new Promise(function(resolve, reject) {
          var reader = new FileReader()
         reader.readAsDataURL(file)// 这里是最关键的一步,转换成base64
          reader.onload = function(event) {
            _this.Form.imageurl.push(event.target.result) //定义参数获取图片路径
          }
        })

script部分的代码

 

定义一个imageurl数组来接收传入的图片base64码,然后在保存在form对象中传过去给Node后端保存到数据库中,这里我用的是mongodb数据库,可以看到数据已经传到数据库了,imgdata就是存放图片base64的对象。

Vue如何使用Element-ui表单发送数据与多张图片到后端详解_第3张图片

 自此已成功完成该问题

总结

到此这篇关于Vue如何使用Element-ui表单发送数据与多张图片到后端的文章就介绍到这了,更多相关Vue用Element-ui发送数据到后端内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(Vue如何使用Element-ui表单发送数据与多张图片到后端详解)