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>

其实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测试时那样

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

   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错误,但是不影响最终效果,介意的可以看看有什么方法去除

方案三 分多次传值

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

时间: 2025-02-01 19:55:05

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

饿了么Element UI之Upload组件图片上传【原创】

图片文件换汤不换药,只要注意前端的写法即可 1.饿了么组件可以利用 http-request 的属性对上传进行自定义 :http-request="uploadFile" 2.设置文件FormData对象传入请求 const formdata = new FormData(); const file = params.file; formdata.append("file", file); 3.全部代码 <template> <div style=

在使用element ui时 select组件获取label问题

最近在工作的时候需要实现多个条件联合查询,这个其实就是一条sql语句.但是,我们数据库中存储的是根据前端传来id的值所对应的值,而不是直接存的id,使用select组件时,却只能取到value值,无法作为后台查询的条件. 我们需要的是select 组件的label值,而不是看不见的value值. 首先,根据element ui select组件使用手册,给组件添加'change'方法 1 @change=changeValue 再根据Array 的 find方法找出对应的值即可. 1 chang

AmazeUI(妹子UI)中CSS组件、JS插件、Web组件的区别

AmazeUI(妹子UI)是非常优秀的国产前端UI,现在来介绍一下AmazeUI中CSS组件.JS插件与Web组件的区别. CSS组件顾名思义就是仅使用CSS渲染而成的组件,而JS插件也很容易理解,就是由CSS渲染和JS来控制行为的组件.比较不好理解就是Web组件,好像跟JS插件意思差不多,都是CSS和JS组成的.它们到底区别在哪?我们重点来讲这个.我们通过学习如何调用Web组件(其中的手风琴组件)来一步一步了解其与JS插件的区别. 示例01.Web组件-直接使用 (请下载附件查看示例) 示例中

vue+element UI实现分页组件

1.前言 在web页面中,常常需要将后台查询到的数据以表格形式展示出来,而这些数据量往往会非常庞大,如果将所有要展示的数据一次性请求获取并展示到页面上,那页面长度势必会变得非常的长,很不美观.更重要的是,如果数据量过于大,在页面加载时一次性请求全部数据将会耗费大量网络资源,性能极低.但是,如果我们可以将数据分页展示,这样页面首先不会变的冗长,另外只有用户点击页码才会发出请求并且每次请求的数据量也不会很大,这就极大的节省了网络资源,提高了性能.本文就以vue结合element UI实现一个数据分页

Element UI 中被隐藏的滚动条

Element UI 官网中有用到自定义的滚动条组件,但是发布的所有版本中都不曾提及,个中原因我们不得而知,不过我们还是可以拿过来引用到自己的项目中. 使用的时候,放在 <el-scrollbar></el-scrollbar> 标签内即可如: <div style="height:100%"> <el-scrollbar class="m-scroll" style="height:100%">

Element ui 中使用table组件实现分页记忆选中

我们再用vue和element-ui,或者其他的表格的时候,可能需要能记忆翻页勾选,那么实现以下几个方法就ok了 首先定义个data值 data () { return { multipleSelectionAll: [], // 所有选中的数据包含跨页数据 idKey: 'personId' // 标识列表数据中每一行的唯一键的名称(需要按自己的数据改一下) } } 方法中定义以下: methods : { // 设置选中的方法 setSelectRow() { if (!this.multi

Element ui 的树形组件使用的 jsx 写法无法运行。

传统后台开发人员.最近写管理后台使用了element-ui .在tree这这个组件的自定义节点上碰到问题了.官方文档在这里:http://element-cn.eleme.io/#/zh-CN/component/tree源代碼: 文档提示: 使用render-content指定渲染函数,该函数返回需要的节点区内容即可.渲染函数的用法请参考 Vue 文档.注意:由于 jsfiddle 不支持 JSX 语法,所以本例在 jsfiddle 中无法运行.但是在实际的项目中,只要正确地配置了相关依赖,就

element ui dialog 父子组件传值

最近在做课设的时候?用到了Elementui?中的dialog的组件,但在将dialog作为一个子组件的时候,传值出现了问题.当关闭dialog的时候应该怎么传值? ? 一开始的时候的想法比较简单,就是父组件直接传值来作为子组件的show/hidden的值. 然而这样的问题是当子组件close的时候,他会直接直接改变他的值,但是子组件不能直接改变props的值,因此可以通过子组件触发事件给父组件. ? 子组件在关闭时候的事件,通过阅读官方文档,我们发现他提供了一个关闭的时候的回调事件. 我们可以

element ui 中的时间选择器,禁用今天以前的时间

<el-date-picker v-model="baseInfo.addTime" type="datetime" placeholder="选择时间" :picker-options="pickerOptions"></el-date-picker> pickerOptions: { disabledDate(time) { return time.getTime() < Date.now()