antdVue--Upload使用
1.实现功能:文件上传、下载以及删除 不过API中的下载监听方法download一直没有触发,(不确定是我写的有问题还是咋地,反正就是触发不了下载)随用预览的监听方法preview来实现了下载。
组件调用
<new-upload
ref="upDataMout"
:uploadActionUrl="url.uploadAction"
:urlDownload="url.urlDownload"
:deleteUrl="url.deleteUrl"
@uploadFile="uploadFile"
>
</new-upload>
自定义上传组件
<template> <a-upload
name="file"
:multiple="true"
:disabled="disabled"
:file-list="fileList1"
@change="handleUpload"
@preview="download"
:remove="handleRemove"
:before-upload="beforeUpload"
:showUploadList="{
showDownloadIcon:true,
showRemoveIcon:true
}"
>
<a-button size="small"><a-icon type="upload" style="font-size: 12px;"/>{{ text }}</a-button>
</a-upload> </template> <script>
import axios from 'axios'
import Vue from 'vue'
import {postAction} from '@/api/analysis.js' //接口请求的文件
const FILE_TYPE_ALL = "all" export default {
name: 'JUpload',
data(){
return {
formData:{},//接口传参
fileList1: [],
filedirList:[],
nameList:[],
uploading: false,
}
},
props:{
text:{
type:String,
required:false,
default:"点击上传"
},
fileType:{
type:String,
required:false,
default:FILE_TYPE_ALL
},
value:{
type:[String,Array],
required:false
},
// update-begin- --- author:wangshuai ------ date:20190929 ---- for:Jupload组件增加是否能够点击
disabled:{
type:Boolean,
required:false,
default: false
},
// 用于动态传参修改上传路径
uploadActionUrl:{
type:String,
required:false,
default:"",
},
// 下载地址的动态传参
urlDownload:{
type:String,
required:false,
default:"",
},
deleteUrl:{//删除文件的接口
type:String,
required:false,
default:"",
}
},
methods:{
uidGenerator(){//随机生成
return '-'+parseInt(Math.random()*10000+1,10);
},
add(){//新增原来老数据清空
this.$nextTick(() => {
this.fileList1 = [];
this.filedirList = [];
this.nameList = [];
})
},
edit(recode){//编辑文件回显
console.log("编辑1111",recode);
const data = recode;
const fileName = data.fileName?data.fileName.split(","):[];
const filedir=data.folderId?data.folderId:'';
this.fileList1 = [];
let fileList = [],filedirList=[];
for(var a=0;a<fileName.length;a++){
fileList.push({
uid:this.uidGenerator,
name:fileName[a],
status: 'done',
url: filedir,
response:{
status:"history",
message:filedir
}
});
filedirList.push(filedir);
}
this.$nextTick(() => {
this.fileList1 = fileList;
this.filedirList = filedirList;
this.nameList = fileName;
})
},
handleRemove(file) {//删除文件
this.$confirm("确认删除该文件?",{
type:'error'}).then(()=>{
console.log("确认操作");
const index = this.fileList1.indexOf(file);
const newFileList = this.fileList1.slice();
newFileList.splice(index, 1);//把当前的文件删除
this.fileList1 = newFileList;
const fileName = file.name;
const filedir = this.filedirList[index];//文件地址数组
let newPathList = this.filedirList.slice();
newPathList.splice(index,1);//删除当前文件名
this.filedirList = newPathList; let newNameList = this.nameList.slice();
newNameList.splice(index,1);//删除当前文件名
this.nameList = newNameList;
let url = `${this.deleteUrl}?fileName=${fileName}&filedir=${filedir}`;
let that = this;
postAction(url).then((res) => {
if(res.status==1) {
let paras={
'fileName':newNameList,
'filedir':that.filedirList[0]
}
that.$emit('uploadFile', paras);//文件数据传给父组件
that.$message.success(`删除成功!`);
}
})
}).catch(()=>{
console.log("取消操作");
})
},
beforeUpload(file) {
this.fileList1 = [...this.fileList1, file];
return false;
},
handleUpload(file) {//文件上传监听
console.log("file:",file);
const { fileList1,filedirList,nameList } = this;
const formData = new FormData();
fileList1.forEach(file => {
formData.append('files', file); //文件上传的时候传参
if(file.status!="done" && fileList1.length>1){
formData.append('filedir', filedirList[0]); //文件上传的时候传参
}
});
this.uploading = true;
let that =this;
if(file.file.status=="removed"){//删除状态
return;
}
//文件上传接口请求
axios({
method: "POST",
url: `${this.uploadActionUrl}`,
data: formData,
headers: {
'Content-Type': 'multipart/form-data'
}
}).then(function(res) {
if(res.status==200){
const data = res.data;
let path = filedirList,name = nameList;
path.push(data.filedir);
name.push(file.file.name);
that.nameList = name;
//文件夹id,一个任务一个id即同一个新增上传多个文件都是同一个id
that.filedirList = path; console.log("path:",that.filedirList);
that.fileList1[that.fileList1.length-1].url=data.filedir;//接口返回的上传路径
that.fileList1[that.fileList1.length-1].status="done";//必须该状态下才可以预览和下载 that.$message.success(`${data.fileName} 上传成功!`);
let paras={
'fileName':nameList,
'filedir':that.filedirList[0]
}
that.$emit('uploadFile', paras);//文件数据传给父组件
}
console.log(res);
}).catch(function(error){
console.log(error);
this.$message.warning(error.response);
}); },
download(file){//下载文件
// console.log("fileL:",file);
const index = this.fileList1.indexOf(file);
const filedir=this.filedirList[index];
const that = this;
let url = `${this.urlDownload}?fileName=${file.name}&filedir=${filedir}`;
window.open(url);//下载文件 }, },
model: {
prop: 'value',
event: 'change'
}
}
</script> <style scoped> </style>
antdVue--Upload使用的更多相关文章
- AntdVue使用
AntdVue使用 配置与安装 #安装 npm install ant-design-vue --save #按需加载 import { Button, Layout, Row, Col, Menu, ...
- 解决ngnix服务器上的Discuz!x2.5 Upload Error:413错误
1.修改php.ini sudo nano /etc/php5/fpm/php.ini #打开php.ini找到并修改以下的参数,目的是修改上传限制 max_execution_time = 900 ...
- 页面无刷新Upload File
页面无刷新Upload File. 利用jquery.form.js的ajaxForm提交文件. 具体参考以下代码: 前台html <%@ Page Language="C#" ...
- 基于Picture Library创建的图片文档库中的上传多个文件功能(upload multiple files)报错怎么解决?
复现过程 首先,我创建了一个基于Picture Library的图片文档库,名字是 Pic Lib 创建完毕后,我点击它的Upload 下拉菜单,点击Upload Picture按钮 在弹出的对话框中 ...
- 多文档上传(upload multiple documents)功能不能使用怎么办?
问题描述: 在SharePoint 2010的文档库里选择documents标签,然后选择upload document下拉菜单,你会发现upload multiple documents那个按钮是灰 ...
- web 前端常用组件【06】Upload 控件
因为有万恶的IE存在,所以当Web项目初始化并进入开发阶段时. 如果是项目经理,需要知道客户将会用什么浏览器来访问系统. 明确知道限定浏览器的情况下,你才能从容的让手下的封装必要的前端组件. 本篇文章 ...
- AzCopy Upload Files
We can use many ways upload our Files to Azure, Than I Introduction to you a good way, AzCopy ! 1. ...
- upload&&download
package am.demo; import java.io.File; import java.io.IOException; import java.util.Iterator; imp ...
- jQuery File Upload 单页面多实例的实现
jQuery File Upload 的 GitHub 地址:https://github.com/blueimp/jQuery-File-Upload 插件描述:jQuery File Upload ...
- jQuery File Upload done函数没有返回
最近在使用jQuery File Upload 上传图片时发现一个问题,发现done函数没有callback,经过一番折腾,找到问题原因,是由于dataType: ‘json’造成的,改为autoUp ...
随机推荐
- perl的学习:将分句脚本split-sentences.perl转为python脚本
初识perl,只为完成分句脚本的转换.因此本文具有极强的目的性,perl的很多好用功能就不研究了,主要内容围绕分句脚本展开,部分基础知识就不再赘述. 1.仓库的地址:https://gitee.com ...
- react+routerv6搭建项目
目标配置:React + Hook + React-router-v6 + Mobx + AntD: 1.创建项目 npx npx create-react-app 项目名称 2.安装sass环境,r ...
- 2022-05-24内部群每日三题-清辉PMP
1.一家公司具有一项变更控制委员会(CCB)政策,规定其每月举行一次会议来评估和审查变更请求.一个项目正在执行过程中,由于时间表和目标较为激进,需要更快的响应时间.项目经理应该怎么做? A.更新风险登 ...
- jenkins目录
Jenkins目录详解: jobs目录:创建的所有jenkins工程.并含有所有构建历史记录和日志.其中config.xml为具体配置. plugins:所有插件 workspace:构建工程本机源码 ...
- fastdfs java客户端操作
https://github.com/happyfish100/fastdfs-client-java 到此处下载下来demo 这里采用maven的方式 mvn clean install 上传到本地 ...
- vue封装全局确认弹窗
下载文件1.弹窗组件 <template> <view class="bombFrame" v-if="bshow" :class=" ...
- Linuxt通过命令lsof或者extundelete工具恢复误删除的文件或者目录
Linux不像windows有那么显眼的回收站,不是简单的还原就可以了.linux删除文件还原可以分为两种情况,一种是删除以后在进程存在删除信息,一种是删除以后进程都找不到,只有借助于工具还原.这里分 ...
- 【Go】类型转换
字符串转int32 package main import ( "fmt" "strconv" ) func main() { str := "123 ...
- Springboot+Vue实现短信与邮箱验证码登录
体验网址:http://mxyit.com 示例 1.新增依赖 <!-- 短信服务 --> <dependency> <groupId>com.aliyun< ...
- ES实战- data too large, data for
场景 客户现场业务系统突然查询不到数据,个人一开始分析以为是聚合查询报错,于是去看了下系统日志,看到如下日志打印: Caused by: ElasticsearchStatusException[El ...