vue+element_ui上传文件,并传递额外参数操作


Posted in Vue.js onDecember 05, 2020

需求:

1、文件大小验证

2、文件类型验证

3、额外参数传输

<template>
 <el-upload class="upload-demo" action :limit="1" :file-list="formFileList" :http-request="handleUploadForm" :on-exceed="formHandleExceed" :on-remove="formHandleRemove"
 :before-upload="beforeUploadForm" accept=".csv,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.ms-excel">
    <el-button type="primary">上传文件</el-button>
    <span slot="tip" class="el-upload__tip" style="margin: 0 10px;">只能上传xlsx/xls/csv文件,且不超过{{formMaxSize}}M</span>
  </el-upload>
</template>
<script>
export default {
 data () {
 return {
  formMaxSize: 10, // 上传文件大小
  formFileList: [], // 显示上传文件
  uploadFormFileList: [] // 确定上传文件
 }
 },
 methods: {
 // 开始上传前验证
 beforeUploadForm (file) {
  // 验证文件大小
  if (file.size / 1024 / 1024 > this.formMaxSize) {
  this.$message({
   message: `上传文件大小不能超过${this.formMaxSize}M!`,
   type: 'warning'
  })
  return false
  }
  // 中文乱码处理
  if (file.raw) {
  let reader = new FileReader() // 读取文件内容
  reader.readAsText(file.raw, 'gb2312') // 防止中文乱码问题,不加reader.onload方法都不会触发
  reader.onload = function (e) {
   this.contentHtml = e.target.result // txt文本内容,接下来就可以对其进行校验处理了
  }
  }
  // 验证文件类型
  var testmsg = file.name.substring(file.name.lastIndexOf('.') + 1)
  const extension = testmsg === 'xlsx' || testmsg === 'xls' || testmsg === 'csv'
  if (!extension) {
  this.$message({
   message: '上传文件只能是xlsx/xls/csv格式!',
   type: 'warning'
  })
  }
  return extension
 },
 // 移除上传列表中文件
 formHandleRemove (file, formFileList) {
  let thiz = this
  for (let i = 0; i < thiz.uploadFormFileList.length; i++) {
  if (thiz.uploadFormFileList[i].pname === file.name) {
   thiz.uploadFormFileList.splice(i, 1)
   break
  }
  }
 },
 // 允许上传文件个数验证
 formHandleExceed (files, formFileList) {
  this.$message.warning(`当前限制选择 1 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + formFileList.length} 个文件`)
 },
 // 上传文件
 handleUploadForm (param) {
  let thiz = this
  let formData = new FormData()
  formData.append('uid', '上传文件编号') // 额外参数
  formData.append('files', param.file)
  let loading = thiz.$loading({
  lock: true,
  text: '上传中,请稍候...',
  spinner: 'el-icon-loading',
  background: 'rgba(0, 0, 0, 0.7)'
  })
  thiz.$axios.post('http://localhost:8080/upload/file', formData).then(({data}) => {
  if (data.statusCode === 233) {
   thiz.$message('上传文件成功,' + data.message)
   thiz.formFileList = []
   thiz.uploadFormFileList = []
  } else {
   thiz.formFileList = []
   thiz.uploadFormFileList = []
   thiz.$message('上传文件失败,' + data.message)
  }
  loading.close()
  })
 }
 }
}
</script>
<style lang="scss" scoped>
</style>

总结:

关于el-upload中各属性的配置,可以看element_ui官网

后端接受上传文件和额外参数:

@RequestParam(value = "uid") String uid, @RequestParam(value = "files") MultipartFile[] files

补充知识:vue利用elementUI上传文件以及其他参数的处理方式

将文件自动上传改为false

:auto-upload="false"

点击保存的时候,调用el-upload的上传方法

代码如下(封装的上传方法)

export function mpp(data) {
 return new Promise(function(resolve, reject) {
  let data = {
   method: "POST",
   url:url,
   data:data
  }
  resolve(axios(data));
 })
}
<template>
<!--导入计划 -->
<div class="associationPlan">
 <el-form :model="dataModel" :rules="rules" ref="associationPlan" label-width="100px">
    <el-form-item label="项目名称:" prop="projectArry">
      <el-cascader :options="listOrgInfoList" v-model="dataModel.projectArry" :props="defaultProp" size="small" placeholder="请选择项目" style="width:100%;" clearable :disabled="isCompany"></el-cascader>
    </el-form-item>
     <el-form-item label="计划级别:" prop="level">
      <el-select size="small" v-model="dataModel.level" placeholder="请选择:" clearable style="width:100%;">
        <el-option v-for="(item,index) in planTypeList" :label="item.name" :value="item.number" :key="index"></el-option>
      </el-select>
      <span class="warnInfo" v-if="dataModel.level==1">一级进度计划匹配项目总工期,项目下只可建立一个,请确认后再添加!</span>
    </el-form-item>
    <el-form-item label="计划名称:" prop="name">
      <el-input v-model.number="dataModel.name" size="small"></el-input>      
    </el-form-item>   
    <el-form-item label="导入计划:">
     <el-upload accept=".mpp" style="display:inline-block;vertical-align: top;" ref="uploadAdd" action="" :auto-upload="false" :http-request="uploadImg" :on-success="uploadImgSuccess" :on-remove="handleRemove">
      <el-button size="small" type="success">请选择文件</el-button>
     </el-upload> 
    </el-form-item>
        
 </el-form>
 <div class="clickBtn">
  <el-button @click="close" size="small">取消</el-button>
  <el-button @click="commit" size="small" type="primary">保存</el-button>
 </div>
</div>
</template>
<script>
import { mapState, mapActions } from 'vuex';
import { plan,mpp} from "../api/system_interface.js";
export default {
 name: "associationPlan",
 data() {
  return {
   dataModel: {
    projectId: '',
    projectArry:[],
    level:null,
    name:'',
    parentId:'0'
   },
   defaultProp: {
    children: "child",
    label: "name",
    value: "id"
   },
   //数据校验
   rules: {
    projectArry:  [{ required: true, message: "请选择项目", trigger: "blur" }],
    name:  [{ required: true, message: "请输入计划名称", trigger: "blur" }],
    level:  [{ required: true, message: "请选择计划级别", trigger: "change" }]
   
   },
   file:false,
   isCompany:false 
  };
 },
 computed: {
  ...mapState([
   'listOrgInfoList',
   'planTypeList'
  ]),
 },
 methods: {
   ...mapActions([
   'getlistOrgInfoList'
  ]),
 
  update(){
   let companyTypes = sessionStorage.getItem("companyType");
   this.isCompany = companyTypes == 4?true:false;
   this.dataModel.projectArry = JSON.parse(sessionStorage.getItem("selectArry"));
  },
 
  uploadImg (f) {
    //  if(!f){
    //  this.$message.error("请上传文件!");
    //  return
    // }
     this.dataModel.projectId = this.dataModel.projectArry[this.dataModel.projectArry.length - 1];
     let param = new FormData(); //创建form对象
     param.append('file',f.file);//通过append向form对象添加数据
     param.append('level',this.dataModel.level);//添加form表单中其他数据
     param.append('projectId',this.dataModel.projectId);//添加form表单中其他数据
     param.append('planName',this.dataModel.name);//添加form表单中其他数据
     mpp(param)//上传
     .then(response=>{
      if(response.code == "200"){
       this.$message.success("上传成功!");
       this.close();
       this.$emit("refreshData");  
       onSuccess(response.data);     
      }        
     })
     .catch(({err}) => {
      f.onError()
     })  
   },
   uploadImgSuccess(response, file, fileList) {
     // 缓存接口调用所需的文件路径
     console.log('文件上传成功')
    // this.$message.success("上传成功!");
   },
   handleRemove(file, fileList) {
     // 更新缓存文件
     console.log('文件删除')
   },
 
  //重置方法
  reset() {
   const associationPlan = this.$refs["associationPlan"];
   associationPlan.resetFields();
   this.dataModel.projectId = null;
   this.dataModel.name = '';
   this.dataModel.level = '';
   this.dataModel.projectArry = [];
  },
 
  //关闭弹框
  close() {
   this.$emit("close");
   this.reset();
  },
 
  //点击提交
  commit() {
   this.$refs["associationPlan"].validate(valid => {
    if (!valid) {
     return;
    }
    this.$refs.uploadAdd.submit();
    // this.dataModel.projectId = this.dataModel.projectArry[this.dataModel.projectArry.length - 1];
    // plan(this.dataModel)
    // .then(response => {
    //  if (response.code == "200") {
    //   this.$message.success("添加成功!");
    //   this.close();
    //   this.$emit("refreshData");
    //  } else {
    //   this.$message.error(response.msg);
    //  }
    // })
    // .catch(error => {
    // });
   });
  },
 
 }
};
</script>
<style lang="scss" scoped>
.clickBtn {
 text-align: center;
}
.warnInfo{
 // color: #feba51;
 color: rgb(64, 158, 255);
}
</style>

以上这篇vue+element_ui上传文件,并传递额外参数操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
Vue 简单实现前端权限控制的示例
Dec 25 Vue.js
vue3自定义dialog、modal组件的方法
Jan 04 Vue.js
vue仿携程轮播图效果(滑动轮播,下方高度自适应)
Feb 11 Vue.js
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 Vue.js
Vue多选列表组件深入详解
Mar 02 Vue.js
详解Vue.js 可拖放文本框组件的使用
Mar 03 Vue.js
vue中三级导航的菜单权限控制
Mar 31 Vue.js
Vue3中toRef与toRefs的区别
Mar 24 Vue.js
vue 自定义组件添加原生事件
Apr 21 Vue.js
Vue深入理解插槽slot的使用
Aug 05 Vue.js
vue本地构建热更新卡顿的问题“75 advanced module optimization”完美解决方案
Aug 05 Vue.js
Vue router配置与使用分析讲解
Dec 24 Vue.js
解决vue下载后台传过来的乱码流的问题
Dec 05 #Vue.js
解决Vue-cli3没有vue.config.js文件夹及配置vue项目域名的问题
Dec 04 #Vue.js
vue基于Echarts的拖拽数据可视化功能实现
Dec 04 #Vue.js
vue使用echarts图表自适应的几种解决方案
Dec 04 #Vue.js
vue-calendar-component 封装多日期选择组件的实例代码
Dec 04 #Vue.js
如何正确解决VuePress本地访问出现资源报错404的问题
Dec 03 #Vue.js
vue表单验证之禁止input输入框输入空格
Dec 03 #Vue.js
You might like
风格模板初级不完全修改教程
2006/10/09 PHP
PHP禁止页面缓存的代码
2011/10/23 PHP
MyEclipse常用配置图文教程
2014/09/11 PHP
分享下php5类中三种数据类型的区别
2015/01/26 PHP
PHP 极验验证码实例讲解
2016/09/29 PHP
PHP实现二维数组按某列进行排序的方法
2016/11/18 PHP
PHP PDOStatement::fetch讲解
2019/01/31 PHP
扩展String功能方法
2006/09/22 Javascript
javaScript 数值型和字符串型之间的转换
2009/07/25 Javascript
从父页面读取和操作iframe中内容方法
2009/07/25 Javascript
jQuery实现可收缩展开的级联菜单实例代码
2013/11/27 Javascript
js验证IP及子网掩码的合法性有效性示例
2014/04/30 Javascript
JavaScript中使用Object.create()创建对象介绍
2014/12/30 Javascript
微信jssdk在iframe页面失效问题的解决措施
2016/03/03 Javascript
BootStrap+Angularjs+NgDialog实现模式对话框
2016/08/24 Javascript
浅述节点的创建及常见功能的实现
2016/12/15 Javascript
详解在Angularjs中ui-sref和$state.go如何传递参数
2017/04/24 Javascript
jQuery 表单序列化实例代码
2017/06/11 jQuery
node中使用es5/6以及支持性与性能对比
2017/08/11 Javascript
vue.js,ajax渲染页面的实例
2018/02/11 Javascript
vue.js删除列表中的一行
2018/06/30 Javascript
sortable+element 实现表格行拖拽的方法示例
2019/06/07 Javascript
H5实现手机拍照和选择上传功能
2019/12/18 Javascript
[03:22]DSPL第一期精彩集锦:酷炫到底!
2014/11/07 DOTA
[34:39]DOTA2上海特级锦标赛主赛事日 - 4 败者组第四轮#1COL VS EG第二局
2016/03/05 DOTA
python多进程中的内存复制(实例讲解)
2018/01/05 Python
Python使用Selenium模块实现模拟浏览器抓取淘宝商品美食信息功能示例
2018/07/18 Python
详解Python_shutil模块
2019/03/15 Python
python集合常见运算案例解析
2019/10/17 Python
python 两个数据库postgresql对比
2019/10/21 Python
Python Process多进程实现过程
2019/10/22 Python
Python argparse模块使用方法解析
2020/02/20 Python
通过Canvas及File API缩放并上传图片完整示例
2013/08/08 HTML / CSS
感恩母亲节活动方案
2014/03/04 职场文书
绩效管理实施方案
2014/03/19 职场文书
2015上半年个人工作总结
2015/07/27 职场文书