vue之Element 上传组件 el-upload

2019-11-06  本文已影响0人  小北呀_

1.第一种自动上传,需提前写好接口地址和请求参数


<template>
    <div>
      <el-form>
        <el-upload
          :show-file-list="false"
          :limit="1"
          :action= actionUp
          :before-upload="beforeFile"
          :on-success="successFile"
          :data="reportData"
          :file-list="fileList">
          <el-button size="small" type="primary">上传</el-button>
        </el-upload>
      </el-form>
    </div>
</template>

<script>
    export default {
        data() {
            return {
              actionUp:'http://XXXXX',//接口地址
              fileList:[],
              reportData:{  //请求带的参数
                mold:4,
                name:'123111'
              }
            }
        },
        methods: {
          /**
           * 文件上传之前 判断格式
           * */
          beforeFile(file){
            let name = file.name
            let type = name.substring(name.lastIndexOf('.')+1)
            if (type !== 'docx') {
              this.$message('请上传word文件格式');
              return false
            }
          },
          /**
           *文件上传成功时的钩子
           * */
          successFile(file){
            this.$message({
              message: '上传成功',
              type: 'success',
              duration:1000
            })
          },

        }
    }
</script>
成功Network:
接口

1.第二种使用http-request ,覆盖默认的上传行为,可以自定义上传的实现。

<template>
    <div>
      <el-form>
        <el-upload
          :show-file-list="false"
          :limit="1"
          :action= actionUp
          :before-upload="beforeFile"
          :http-request="fileRequest"
          :file-list="fileList">
          <el-button size="small" type="primary">上传</el-button>
        </el-upload>
      </el-form>
    </div>
</template>

<script>
    export default {
        data() {
            return {
              actionUp:'aaaa',
              fileList:[],
            }
        },
        methods: {
          /**
           * 文件上传之前 判断格式
           * */
          beforeFile(file){
            let name = file.name
            let type = name.substring(name.lastIndexOf('.')+1)
            if (type !== 'docx') {
              this.$message('请上传word文件格式');
              return false
            }
          },
          fileRequest(item) {
            let uploadData = new FormData()
            uploadData.append('file',item.file)
            this.$axios.post('http:/XXXXX',uploadData
            )
              .then(res =>{
              //  成功
                console.log('8888')
              })
          }
        }
    }
</script>

上一篇 下一篇

猜你喜欢

热点阅读