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 + el-form 实现的多层循环表单验证
Nov 25 Vue.js
vue3.0+vue-router+element-plus初实践
Dec 02 Vue.js
Vue解决移动端弹窗滚动穿透问题
Dec 15 Vue.js
vue图片裁剪插件vue-cropper使用方法详解
Dec 16 Vue.js
antdesign-vue结合sortablejs实现两个table相互拖拽排序功能
Jan 08 Vue.js
vue实现简易计算器功能
Jan 20 Vue.js
如何在vue 中使用柱状图 并自修改配置
Jan 21 Vue.js
Vue如何实现组件间通信
May 15 Vue.js
使用Vue3+Vant组件实现App搜索历史记录功能(示例代码)
Jun 09 Vue.js
vue中控制mock在开发环境使用,在生产环境禁用方式
Apr 06 Vue.js
vue报错function () { [native code] },无法出现我们想要的内容 Unknown custom element
Apr 11 Vue.js
vue router 动态路由清除方式
May 25 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
PHP中实现图片的锐化
2006/10/09 PHP
刚才在简化php的库,结果发现很多东西
2006/12/31 PHP
VB中的RasEnumConnections函数返回632错误解决方法
2014/07/29 PHP
[原创]ThinkPHP让../Public在模板不解析(直接输出)的方法
2015/10/09 PHP
Codeigniter控制器controller继承问题实例分析
2016/01/19 PHP
自写的利用PDO对mysql数据库增删改查操作类
2018/02/19 PHP
一个可绑定数据源的jQuery数据表格插件
2010/07/17 Javascript
如何让页面在打开时自动刷新一次让图片全部显示
2012/12/17 Javascript
js多级树形弹出一个小窗口层(非常好用)实例代码
2013/03/19 Javascript
jquery 表格的增行删行实现思路
2013/03/21 Javascript
Js实现当前点击a标签变色突出显示其他a标签回复原色
2013/11/27 Javascript
z-blog SyntaxHighlighter 长代码无法换行解决办法(基于jquery)
2015/11/18 Javascript
基于javascript实现listbox左右移动
2016/01/29 Javascript
JavaScript知识点总结(十)之this关键字
2016/05/31 Javascript
Javascript类型系统之undefined和null浅析
2016/07/13 Javascript
浅谈js之字面量、对象字面量的访问、关键字in的用法
2016/11/20 Javascript
微信小程序自定义对话框弹出和隐藏动画
2018/07/19 Javascript
JS遍历JSON数组及获取JSON数组长度操作示例【测试可用】
2018/12/12 Javascript
javascript实现移动端红包雨页面
2020/06/23 Javascript
[02:17]TI4西雅图DOTA2前线报道 啸天mik夫妻档解说
2014/07/08 DOTA
python实现爬虫统计学校BBS男女比例(一)
2015/12/31 Python
Python 爬虫爬取指定博客的所有文章
2016/02/17 Python
Python+Selenium自动化实现分页(pagination)处理
2017/03/31 Python
Python定义一个跨越多行的字符串的多种方法小结
2018/07/19 Python
在ubuntu16.04中将python3设置为默认的命令写法
2018/10/31 Python
pytorch自定义初始化权重的方法
2019/08/17 Python
利用Python的folium包绘制城市道路图的实现示例
2020/08/24 Python
Django如何实现防止XSS攻击
2020/10/13 Python
HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
2018/01/03 HTML / CSS
Michael Kors香港官网:美国奢侈品品牌
2019/12/26 全球购物
大学生应聘自荐信
2013/10/11 职场文书
护士岗位求职应聘自荐书范文
2014/02/12 职场文书
服装设计师职业生涯规划范文
2014/02/28 职场文书
我的大学四年规划书范文2014
2014/09/26 职场文书
银行授权委托书样本
2014/10/13 职场文书
2015年施工员工作总结范文
2015/04/20 职场文书