vue.js+elementUI文件上传、文件导入、文件下载
1.文件下载
<el-button plain @click ="exportVmExcel()" size='mini' icon="el-icon-download" style="margin-left:10px;">模板下载</el-button> exportVmExcel() {
var language = i18n.locale;
console.log("language==="+language);
//模板下载
Api.templateDownload(language).then(res => {
if (res) {
self.handlerDownloadResult({
res: res,
optionType: "vm-template"
});
}
}) }, //API写法,用户模板下载
templateDownload(language) {
return axios({
method: 'get',
url: '/api/vmachine/download/template?language='+language,
responseType: 'blob'
})
},
2.文件导入
<el-button size='mini' @click="chooseFile" ref="upload"> <i class="fa fa-share" > </i> {{$t('导入')}}</el-button>
<input type="file" v-if = "ishowFile" style="display: none" name ="attence" @change="changeFile($event)" ref ="attenceInput" aria-hidden="true">
<input type="file" style="display: none" name ="attence" @change="changeFile($event)" ref ="attenceInput" aria-hidden="true"> //批量导入,选择文件
chooseFile(){
let isTerminal = this.selectTenant
if(isTerminal){
if(this.jumpOrDialog.tenantId == ''){
this.$message({
message: this.$t('text.vmValidates.message6'),
type: "warning"
});
return
}
}
this.$refs.attenceInput.click();
this.ishowFile = false // 销毁
},
changeFile(val){
this.quantityImport(val)
},
quantityImport(val){
let isLt5M = val.target.files[0].size / 1024 / 1024 <= 5;
this.selectedFile = val.target.files[0];
if (this.isExcel() == true && isLt5M == true) {
let isTerminal = this.selectTenant;
let tenantId = '';
let tenantName = '';
if(isTerminal){
tenantId = this.jumpOrDialog.tenantId
tenantName = this.jumpOrDialog.tenantName
}else{
let userInfo = JSON.parse(localStorage.getItem("userInfo"))
tenantId = userInfo.tenantId
tenantName = userInfo.tenantName
}
let vmData = {
tenantId: tenantId,
pageNum: this.pageNum,
pageSize: this.pageSize
}
let formdata = new FormData();
formdata.append('file', this.selectedFile);
var map = {
formdata:formdata,
}
Api.batchImport(map,tenantId,tenantName,this.createUserId,this.createUserName).then(res => {
if(res.status == '200'){
this.$message.success(this.$t('112.uploadSuccess'));
this.getAllVmRegister(vmData)
this.selectedFile = ""
this.ishowFile = true
}else{
this.$message({
message: this.$t('264845'),
type: "error",
showClose: true,
duration:6000,
});
// this.$message.error(this.$t('ploadFailue'));
this.getAllVmRegister(vmData)
}
}).catch( re => {
if(re.response.data.code == '110'){
var errMessages1 = re.response.data.message;
this.$message({
type: 'error',showClose: true,duration:6000,
message: this.$t('1352.79865.23)
});
}else{
this.$message({
type: 'error',showClose: true,duration:6000,
message: this.$t('15973')
});
}
})
}
this.selectedFile = ""
this.ishowFile = true
},
isExcel() {
let self = this;
let filename = self.selectedFile.name;
let arr = filename.split('.');
if (arr[1] !== 'xls') {
console.log(this.$t('12356'));
this.$message({
message: this.$t('123123'),
type: "error",
showClose: true,
duration:6000,
}); return false;
} else {
return true;
}
},
//API批量新增
batchImport: (data,tenantId,tenantName,createUserId,createUserName) => {
return axios({
method: 'post',
header: {
"Content-Type": "multipart/form-data",
},
url:`/api/vmachine/register/batch?` +'tenantId='+tenantId+'&tenantName='+tenantName+'&createUserId='+createUserId+'&createUserName='+createUserName,
data: data.formdata
})
},
vue.js+elementUI文件上传、文件导入、文件下载的更多相关文章
- js实现分段上传文件
使用js实现分段上传文件,本文使用了FileReader对象,可参考:https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader 1)获取文 ...
- vue+element ui 的上传文件使用组件
前言:工作中用到 vue+element ui 的前端框架,使用到上传文件,则想着封装为组件,达到复用,可扩展.转载请注明出处:https://www.cnblogs.com/yuxiaole/p/9 ...
- vue form表单上传文件
<script src="https://cdn.staticfile.org/vue-resource/1.5.1/vue-resource.min.js">< ...
- Nodejs学习笔记(八)--- Node.js + Express 实现上传文件功能(felixge/node-formidable)
目录 前言 formidable简介 创建项目并安装formidable 实现上传功能 运行结果 部分疑惑解析 写在之后 前言 前面讲了一个构建网站的示例,这次在此基础上再说说web的常规功能---- ...
- JS 异步分段上传文件
为了解决大文件上传 (PHP上传最大限制2GB) 同时为了解决文件上传是对服务器造成的压力 可以通过分段上传解决这个问题,这得益于HTML5开发的file API 前台代码: 引用了进度条插件myPr ...
- Nodejs学习笔记(八)—Node.js + Express 实现上传文件功能(felixge/node-formidable)
前言 前面讲了一个构建网站的示例,这次在此基础上再说说web的常规功能----文件上传,示例以一个上传图片的功能为例子 上传功能命名用formidable实现,示例很简单! PS:最近比较忙,距上一次 ...
- c#+js 使用formdata上传文件
如果不是使用form表单submit的形式,我们可以手动通过formdata传值(针对文件上传等) 比如: <html> <head> <meta name=" ...
- js拖拽上传 文件上传之拖拽上传
由于项目需要上传文件到服务器,于是便在文件上传的基础上增加了拖拽上传.拖拽上传当然属于文件上传的一部分,只不过在文件上传的基础上增加了拖拽的界面,主要在于前台的交互, 从拖拽的文件中获取文件列表然后调 ...
- js无刷新上传文件
传统的文件上传方式 <form action="" method="POST" enctype="multipart/form-data&quo ...
- element-ui upload上传文件并携带参数 使用formData对象
需求:上传文件的时候,需要携带其他的参数 问题:使用upload上传文件时,必须使用formData对象,而其他的参数通过data获取的到的,formData和data是不能同时传输的 解决:获取到的 ...
随机推荐
- 5cms使用sql语句给网站添加内容
<!--list:{$Sql=UPDATE [{pre}Content] SET Indexpic="/uploadfile/201405/25/lsgjyst.jpg",t ...
- postgres 基础SQL语句 增删改
查看已创建的数据库:select datname from pg_database; 查看所有数据库的详细信息:select * from pg_database 创建数据库:create datab ...
- Kubernetes-Pod介绍(四)-Deployment
前言 本篇是Kubernetes第七篇,大家一定要把环境搭建起来,看是解决不了问题的,必须实战. Kubernetes系列文章: Kubernetes介绍 Kubernetes环境搭建 Kuberne ...
- centos7 发送邮件
yum install sendmail mailx sharutils mutt libreport-plugin-mailx -y yum update libreport-plugin-mail ...
- 使用php函数 json_encode ,数据存入mysql
$data = json_encode($array); // 过滤 $data = addslashes($data); // 插入数据库 $db->insert($table_name,ar ...
- AT2305-[AGC010D]Decrementing【博弈论】
正题 题目链接:https://www.luogu.com.cn/problem/AT2305 题目大意 \(n\)个数字两个人进行博弈,每个人的操作为 选择一个大于1的数字减一 之后所有数字除以所有 ...
- CF803G-Periodic RMQ Problem【离散化,线段树,ST表】
正题 题目链接:https://www.luogu.com.cn/problem/CF803G 题目大意 一个长度为\(n\)的序列\(a\)复制\(k\)份连接,要求支持 区间赋值 区间查询最小值 ...
- YbtOJ#853-平面标记【整体二分,凸壳】
正题 题目链接:http://www.ybtoj.com.cn/contest/119/problem/3 题目大意 给出\(n\)个点\((x_i,y_i)\),\(m\)次给出\((k_i,a_i ...
- node.js及npm安装&配置
之前我们在文言文安装教程里写过node.js及npm的安装,这里我们详细写一下. 下载node.js node.js下载分为两种,官网nodejs.org,和国内官网nodejs.cn,国内的童鞋建议 ...
- 洛谷4606 SDOI2018战略游戏(圆方树+虚树)
QWQ深受其害 当时在现场是真的绝望...... 现在再重新来看这个题 QWQ 根据题目所说,我们可以发现,对于每一个集合中的节点,我们实际上就是要求两两路径上的割点的数目 考虑到又是关于点双的题目, ...