element-ui中upload组件如何传递文件及其他参数

element-ui中upload组件如何传递文件及其他参数

最近项目用到了vuethink,里面集成了element-ui,之前一直用的是bootstrap框架,对js也是一知半解,然后也用过vue.js,但也是学的不通透的,然后就各种入坑。

下面就分析一下我使用element-ui遇到的问题以及解决方法吧,如有不足请指正。

首先在element-ui的官网里有对upload组件的简单的介绍

复制代码
1  <el-upload
2    class="upload-demo"
3    action="https://jsonplaceholder.typicode.com/posts/"
4    :on-preview="handlePreview"
5    :on-remove="handleRemove"
6    :file-list="fileList">
7    <el-button size="small" type="primary">点击上传</el-button>
8    <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div>
9 </el-upload>
复制代码

 

element-ui中upload组件如何传递文件及其他参数

其实upload就是对input type=”file”做了几层样式封装

一 action url

我第一个不理解的就是action中的url,我后台使用的是PHP语言,根据我之后的理解,这个url其实就是你PHP使用的上传的函数,就和form中的action一样,不一样的是我找了好久也没发现是否能修改默认的post传递方式

二 文件接收的同时,传递其他参数

方案一 url传参

对PHP提供的url进行传参,这是最直接能想到的方式,但是因为action中是post方式的,而PHP后台我使用的restful方式的url,post方式无法实现传参,我试了好几种都没能成功,也不知道要如何改成get方式

第一种方案只能放弃

方案二 不使用action

 放弃action,在找了好多资料后发现可以不使用action,而是用before-upload属性,这是一个function类型的属性,默认参数是当前文件,只要能传递这个文件也能实现效果

要传递这个方法就需要new一个formdata对象,然后对这个对象追加key和value,类似于postman测试时那样

element-ui中upload组件如何传递文件及其他参数

具体网上有人给的例子,差不多如下

 

复制代码
   beforeUpload (file) {
      let fd = new FormData()
      fd.append('key', file, fileName)
      axios.post(url, fd. {
        //做一些操作
      })
      return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传
    },
复制代码

 

这个感觉可以一试,然后我理所当然的写了一下的方式

复制代码
 1    beforeUpload (file,id) {
 2       let fd = new FormData()
 3       fd.append('key', file, fileName)
 4       axios.post(url, fd. {
 5         data:{
 6          id:id
 7         }
 8       })
 9       return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传
10     },
复制代码

 

然后我发现无论怎么样我都只能传过去id,在PHP代码中dump(_FLIES)永远是NULL,这就非常火大了,查了好久没有解决方法,之后发现我用的Content-Type应该是multipart/form-data,而f12中调试页面是application/json; charset=utf-8,我就觉得是不是这个的问题,于是在代码中又加了headers

复制代码
    beforeUpload (file,id) {
        let fd = new FormData()
        fd.append('key', file, fileName)
        axios.post(url, fd. {
          data:{
           id:id
          },
          headers: {
           'Content-Type': 'multipart/form-data'
          }
        })
        return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传
     },
复制代码

 

这次报的错是axios Missing boundary in multipart/form-data,没有边界,很头疼无语

后来发现Content-Type是自动识别然后加边界的,也有人说要把Content-Type定义为undefined,还是不行,只是自动识别Content-Type,

再后来发现原来传递formdata和data不能一起传递,要传递formdata就不能有data,所以要改为

复制代码
1 beforeUpload (file,id) {
2     let fd = new FormData()
3     fd.append('file', file)
4     fd.append('id',id)
5     axios.post(url, fd, {
6          
7     })
8     return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传
9  },
复制代码

 

这样就可以了

以下是我的代码

复制代码
 1         <el-upload class="upload-demo"
 2             drag
 3             action="123"
 4             :before-upload="beforeUpload"
 5             multiple
 6             ref="newupload"
 7             :auto-upload="false"
 8             accept=".mp4,.flv,.mov"
 9             :on-change="newhandleChange"
10             :on-success="newhandlesuccess">
11             <i class="el-icon-upload"></i>
12             <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em>     </div>
13             <div class="el-upload__tip" slot="tip">请注意您只能上传.mp4 .flv .mov格式的视频文件</div>
14           </el-upload>
15           el-button type="primary" @click="newSubmitForm()" class="yes-btn">
16             确 定
17           </el-button>
18           <el-button @click="resetForm('newform')">
19             重 置
20           </el-button>
复制代码

 

复制代码
 1    beforeUpload (file) {
 2       console.log(file)
 3       let fd = new FormData()
 4       fd.append('file', file)
 5       fd.append('groupId', this.groupId)
 6       // console.log(fd)
 7       newVideo(fd).then(res => {
 8         console.log(res)
 9       })
10       return true
11     },
复制代码

1    newSubmitForm () {
2       this.$refs.newupload.submit()
3     },

 

复制代码
1 export function newVideo (data) {
2   return axios({
3     method: 'post',
4     url: 'http://localhost:8086/Platform1-back-end/public/admin/VideoBase/newVideo',
5     timeout: 20000,
6     data: data
7   })
8 }
复制代码

 

我是把axios集中放在一个文件,与vue文件分离了,其实都差不多

还有就是action中随便加一个东西会有404错误,但是不影响最终效果,介意的可以看看有什么方法去除

方案三 分多次传值

方案二成功了就没有试,不过也没有意义了不方便

http://www.cnblogs.com/liuruolin/p/7517470.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113770.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • IIS设置ISAPI筛选器Rewrite组件防盗链(防盗链可以节省流量,提高性能)

    IIS设置ISAPI筛选器Rewrite组件防盗链(防盗链可以节省流量,提高性能)如何在IIS的设置下添加ISAPI筛选器里的Rewrite组件,防止图片被盗用链接。首先笔者要说的是“盗链”很常见的现象,虽然没有采集那么“流行”,但是对于被盗者来说,碰到这事还真的及时解决,要不资源的消耗很可能会影响自身网站的正常运营。那究竟什么是盗链,怎样防止网站的信息被盗链呢?下面简单的说下:“盗链”的定义是:此内容不在自己服务器上,而通过技术手段,绕过别人放广告有利益的最终页,直接…

    2022年7月23日
    7
  • MySQL练习题(经典50题)

    MySQL练习题(经典50题)MySQL练习题(经典50题)–建表–学生表CREATETABLEStudent(s_idVARCHAR(20),s_nameVARCHAR(20)NOTNULLDEFAULT‘’,s_birthVARCHAR(20)NOTNULLDEFAULT‘’,s_sexVARCHAR(10)NOTNULLDEFAULT‘’,PRIMARYKEY(s_id));–课程表CREATETABLECourse(c_idVARCHAR(20),c_nam

    2022年9月18日
    3
  • 【转载】视频跟踪的研究

    首先,什么是视频跟踪?基于视频的运动目标跟踪技术作为计算机视觉领域的核心研究课题之一, 主要目的是模仿生理视觉系统的运动感知功能,通过对摄像头捕捉到的图像序列进行分析,计算出运动目标在每一帧图像中的二维坐标位置;然后,根据运动目标相关的特征值,将图像序列中连续帧间的同一运动目标关联起来,得到每帧图像中目标的运动参数以及相邻帧图像间运动目标的对应关系,从而得到各个运动目标完整的运动轨迹,即在

    2022年4月10日
    43
  • win10无法生成常规子目录下的列表_windows无法更新怎么办

    win10无法生成常规子目录下的列表_windows无法更新怎么办1.问题背景Win10只要系统安装好之后会自动生成一系列的系统文件夹,如下:这类文件夹比较特殊,它们比普通文件夹多一个“位置”选项卡,如默认的“下载”文件夹,edge和chrome浏览器会默认下载到这个文件夹,所以新系统拿到手之后,往往都需要将这些文件夹修改到其他硬盘上,不然C盘会因为下载文件的不断增多而变得异常臃肿:如果这个时候你手抖了,需要修改……………

    2022年9月18日
    3
  • max31865C语言程序,max31865温度传感器通信驱动代码「建议收藏」

    max31865C语言程序,max31865温度传感器通信驱动代码「建议收藏」最近研究maximmax31865温度传感器,贴出通信驱动代码和大牛门一起学习,指点我一二max31865是专门用来测量电阻类温度传感器的,ad分辨率为15位,可以做PT100高精度测量,通信接口为SPI。通过评估板CN7的PC10,PC11,PC12(SPI3)连接芯片模块,PD2做片选。下面贴上驱动代码:1.///////////////////////////////////////…

    2022年6月14日
    38
  • Windows环境下搭建SVN服务器

    Windows环境下搭建SVN服务器如要转载,请注明来源,小石头的博客: http://blog.csdn.net/lu1024188315使用 VisualSVNServer来实现主要的 SVN功能则要比使用原始的 SVN和Apache相配合来实现源代码的 SVN管理简单的多,下面就看看详细的说明。VisualSVNServer的下载地址如下,是免费的,随意不必有顾虑http://www.visua

    2022年7月19日
    19

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号