-引入弹窗页面
import fileUpload from 'src/page/cuApplyManage/fileUpload.vue';
-页面布局
<div>
<fileUpload ref="dialog" @successReload="fileUploadSuccessReload" ></fileUpload>
</div>
-上传成功后,从上传子页面传值到父页面
fileUploadSuccessReload(data){
let acctData = this.acctFormData;
let dealData = (JSON.stringify(acctData) + JSON.stringify(data)).replace(/{}/, '');
dealData = JSON.parse(dealData.replace(/}{/, ','));
this.acctFormData = dealData ;
}
-按钮打开上传页面
<el-button type="primary" icon="el-icon-upload" @click="showFileUpload">上传</el-button>
-按钮事件
showFileUpload(){
this.$refs.dialog.pvalue = true;
} 上传功能-页面
<el-upload
v-show="true"
accept=".png,.jpg,.pdf"
ref="upload"
action="uploadAction"
:before-upload="beforeUpload"
:http-request="uploadHttpRequest"
:file-list="fileList"
:auto-upload="false"
:show-file-list="true"
:multiple="false"
></el-upload>
uploadHttpRequest(param) {//执行上传动作
var this_ = this;
const formData = new FormData();
formData.append('file', param.file);
const url = this.uploadAction;
let xhr = new XMLHttpRequest();
xhr.open('post',url,true);
xhr.onreadystatechange = function () {
if (xhr.readyState == 4) {
if (xhr.status == 200 || xhr.status == 0) {
this_.onSuccess(JSON.parse(xhr.responseText));
}else{
this_.onError(xhr.responseText);
}
}
}
xhr.send(formData);
},
doUplaod() {//触发uploadHttpRequest
this.$refs.upload.submit();
}
onSuccess(response, file, fileList) {
if (response.code === '000000') {
let retObj = response.data;
this.msgSuccess(response.msg);
this.$emit('successReload',retObj);//返回值到父页面
this.closeDialog();
} else {
this.msgError(response.msg);
}
}

  

上传功能-后端
@RequestMapping(value = "/uploadFileTest")
public ResultEntity uploadFileTest(@RequestParam("file") MultipartFile file) {
logger.info("接收到的文件数据为:" + file);
ResultEntity re = new ResultEntity();
Map<String, Object> retMap = null;
if (file.isEmpty()) {
re.setMsg("上传文件为空");
return re;
}
String fileName = file.getOriginalFilename();
logger.info("上传文件名:" + fileName);
logger.info("文件上传路径:" + fileUploadLocale);
String suffixName = fileName.substring(fileName.lastIndexOf("."));
String prefixName = fileName.substring(0, fileName.lastIndexOf("."));
try {
File dest0 = new File(fileUploadLocale);
File dest = new File(fileUploadLocale ,
prefixName+"-"+ ToolDateTime.getDate(ToolDateTime.PATTERN_YMDHMS)+suffixName);
// 检测是否存在目录
logger.info("上传文件保存名称:" + dest.getName());
if (!dest0.exists()) {
dest0.mkdirs();
}
file.transferTo(dest);
retMap = new HashMap<String, Object>();
retMap.put("bankFileName",dest.getName());
retMap.put("bankFile",dest.getAbsolutePath());
re.data(retMap).ok();
} catch (Exception e) {
logger.error("文件上传错误",e);
re.setMsg("上传文件失败");
}
return re;
}

  

-引入弹窗页面import fileUpload from 'src/page/cuApplyManage/fileUpload.vue';-页面布局    <div>        <fileUpload ref="dialog" @successReload="fileUploadSuccessReload" ></fileUpload>    </div>-上传成功后,从上传子页面传值到父页面fileUploadSuccessReload(data){let acctData = this.acctFormData;let dealData = (JSON.stringify(acctData) + JSON.stringify(data)).replace(/{}/, '');dealData = JSON.parse(dealData.replace(/}{/, ','));this.acctFormData = dealData ;}-按钮打开上传页面    <el-button type="primary" icon="el-icon-upload" @click="showFileUpload">上传</el-button>-按钮事件showFileUpload(){this.$refs.dialog.pvalue = true;}
上传功能-页面<el-uploadv-show="true"accept=".png,.jpg,.pdf"ref="upload"action="uploadAction":before-upload="beforeUpload":http-request="uploadHttpRequest":file-list="fileList":auto-upload="false":show-file-list="true":multiple="false"></el-upload>uploadHttpRequest(param) {//执行上传动作var this_ = this;const formData = new FormData();formData.append('file', param.file);const url = this.uploadAction;let xhr = new XMLHttpRequest();xhr.open('post',url,true);xhr.onreadystatechange = function () {    if (xhr.readyState == 4) {        if (xhr.status == 200 || xhr.status == 0) {            this_.onSuccess(JSON.parse(xhr.responseText));        }else{            this_.onError(xhr.responseText);        }    }}xhr.send(formData);},doUplaod() {//触发uploadHttpRequestthis.$refs.upload.submit();}onSuccess(response, file, fileList) {if (response.code === '000000') {let retObj = response.data;this.msgSuccess(response.msg);this.$emit('successReload',retObj);//返回值到父页面this.closeDialog();} else {this.msgError(response.msg);}}上传功能-后端@RequestMapping(value = "/uploadFileTest")public ResultEntity uploadFileTest(@RequestParam("file") MultipartFile file) {    logger.info("接收到的文件数据为:" + file);    ResultEntity re = new ResultEntity();    Map<String, Object> retMap = null;    if (file.isEmpty()) {        re.setMsg("上传文件为空");        return re;    }    String fileName = file.getOriginalFilename();    logger.info("上传文件名:" + fileName);    logger.info("文件上传路径:" + fileUploadLocale);    String suffixName = fileName.substring(fileName.lastIndexOf("."));    String prefixName = fileName.substring(0, fileName.lastIndexOf("."));    try {        File dest0 = new File(fileUploadLocale);        File dest = new File(fileUploadLocale ,                prefixName+"-"+ ToolDateTime.getDate(ToolDateTime.PATTERN_YMDHMS)+suffixName);        // 检测是否存在目录        logger.info("上传文件保存名称:" + dest.getName());        if (!dest0.exists()) {            dest0.mkdirs();        }        file.transferTo(dest);        retMap = new HashMap<String, Object>();        retMap.put("bankFileName",dest.getName());        retMap.put("bankFile",dest.getAbsolutePath());        re.data(retMap).ok();    } catch (Exception e) {        logger.error("文件上传错误",e);        re.setMsg("上传文件失败");    }    return re;}

最新文章

  1. SharePoint—用REST方式访问列表
  2. java线程详解(一)
  3. 统计《ASP.Net特供视频教程》总长度
  4. &lt;《巴菲特之道 (第三版)》&gt;读书笔记
  5. 李洪强漫谈iOS开发[C语言-025]-赋值运算符案例
  6. 自定义UISlider的样式和滑块
  7. 笔记整理--Linux编程
  8. Java 中的纤程库 – Quasar
  9. 危险 AI 花名册
  10. javascript深入浅出——学习笔记(包装对象和类型检测)
  11. 一篇文章学懂Shell脚本,最简明的教程在这里
  12. 20175208 《Java程序设计》第八周学习总结
  13. java中Map.Entry的使用方法
  14. 【PHP】最详细PHP从入门到精通(一)——想学习PHP的朋友们福利来了!
  15. 框架源码系列九:依赖注入DI、三种Bean配置方式的注册和实例化过程
  16. iOS-野指针与僵尸对象
  17. DDL触发器(用来控制用户的DDL行为)
  18. 使用Spring JPA中Page、Pageable接口和Sort类完成分页排序
  19. ThreadLocal的实现和使用场景
  20. [jquery-delegate] iphone_4s _iphone _5c_中不兼容jQuery delegate 事件(does not wok)

热门文章

  1. PyQt(Python+Qt)学习随笔:QListWidget的访问当前项的currentItem和setCurrentItem方法
  2. java8+ Lambda表达式基本用法
  3. 移动端web网页meta设置
  4. 一文打尽PWM协议、PPM协议、PCM协议、SBUS协议、XBUS协议、DSM协议 | STM32的通用定时器TIM3实现PPM信号输出
  5. 【题解】P3629 [APIO2010]巡逻
  6. 面试 11-01.ES6:模块化的使用和编译环境
  7. 多图详解Go的互斥锁Mutex
  8. PHP面向对象的学习(封装,继承,多态)
  9. [GXYCTF2019]禁止套娃(无参RCE)
  10. robotframework中的参数展开