vue+elementui实现下载模版+导入+导出(不调接口,前端自己做)

  1. 下载模版
    注:模版保存在静态资源下 如:/static/file/test.xlsx
    在这里插入图片描述
<el-button type="text" icon="el-icon-download" @click="onDownload">模版下载</el-button>
//下载模版
 onDownload(){
   
    window.location.href = '/static/file/test.xlsx'
 }
  1. 导入
    注:导入excel文件,并且解析内容渲染在el-table上
    在这里插入图片描述
    安装 file-saver和xlsx插件
npm install file-saver xlsx -S 

main.js中引入依赖

import XLSX from 'xlsx'
Vue.use(XLSX)
<el-upload
    action=""
    :multiple="false"
    :show-file-list="false"
    :http-request="httpRequest"
    accept="csv, application/vnd.ms-excel, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet">
      <el-button type="text" size="small" icon="el-icon-download">导入</el-button>
</el-upload>
httpRequest(e) {
   
	var _this = this;
	var rABS = false; //是否将文件读取为二进制字符串
	let f = e.file // 文件信息
	if(!f) return false;
	else if(!/\.(xls|xlsx)$/.test(f.name.toLowerCase())) {
   
		this.$message.error('上传格式不正确,请上传xls或者xlsx格式')
		return false
	}

	var reader = new FileReader();
	FileReader.prototype.readAsBinaryString = function(f) {
   
		var binary = "";
		var rABS = false; //是否将文件读取为二进制字符串
		var wb; //读取完成的数据
		var outdata;
		var reader = new FileReader();
		reader.onload = function(e) {
   
			var bytes = new Uint8Array(reader.result);
			var length = bytes.byteLength;
			for(var i = 0; i < length; i++) binary += String.fromCharCode(bytes[i]);
			var XLSX = require('xlsx');
			if(rABS) wb = XLSX.read(btoa(fixdata(binary)), {
   type: 'base64'}); //手动转化
			else wb = XLSX.read(binary, {
    type: 'binary' });
			outdata = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]], {
   defval: ''}); //outdata的格式可打印了自行查看
			// 以下是对outdata的格式化,可按个人需要自行转换成渲染table需要的数据
			outdata.map((p, idx)=> {
   
				// ...
			})
		}
		reader.readAsArrayBuffer(f);
	}
	if(rABS) reader.readAsArrayBuffer(f);
	else reader.readAsBinaryString(f);
},

  1. 导出
    注:对已知数组对象类型的数据进行导出excel (下图是点击图标,进行导出日志)
    在这里插入图片描述
    安装依赖
npm install -S file-saver
npm install -S xlsx
npm install -D script-loader

下载导入Blob.js和 Export2Excel.js(文章最后可直接复制使用)
在这里插入图片描述

<el-table-column prop="log" label="日志" align="center">
    <template slot-scope="scope">
      <el-tooltip effect="dark" :content="logtip" placement="right" :visible-arrow="false">
        <img src="@/assets/image/icon-log.svg" class="icon_log" @click.prevent="onDownloadLog(scope.row)" />
      </el-tooltip>
    </template>
</el-table-column>
onDownloadLog(row){
   
       let params = {
   
        rule_id: row.id,
        size: 15
  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用Vue.jsElement UI来实现前端界面,使用Spring Boot来处理后端逻辑来实现文件模板的上传和下载功能。 首先,你可以创建一个Vue组件来处理文件上传和下载的界面。可以使用Element UI中的Upload组件来实现文件上传功能,使用Button组件来实现文件下载功能。在上传组件中,你可以设置上传的文件类型和大小限制,并在上传成功后获取到文件的URL或者其他信息。 接下来,在后端使用Spring Boot来处理上传和下载的逻辑。你可以创建一个Controller来处理文件上传和下载的请求。在文件上传的方法中,你可以使用MultipartFile来接收上传的文件,并将其保存到服务器上的某个目录中。在文件下载的方法中,你可以根据传入的文件名或者其他标识,从服务器上读取相应的文件,并将其以流的形式返回给前端。 以下是一个简单的示例代码: 前端Vue.js + Element UI): ```vue <template> <div> <el-upload class="upload-demo" action="/api/upload" :on-success="handleSuccess" :before-upload="beforeUpload" > <el-button type="primary">点击上传</el-button> </el-upload> <el-button type="primary" @click="downloadTemplate">下载模板</el-button> </div> </template> <script> export default { methods: { handleSuccess(response) { // 处理上传成功后的逻辑 console.log(response); }, beforeUpload(file) { // 设置上传文件的类型和大小限制 const fileType = file.type; const fileSize = file.size / 1024 / 1024; // MB const allowedTypes = ['application/pdf', 'application/msword', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document']; // 允许的文件类型 const maxFileSize = 10; // 允许的最大文件大小,单位:MB if (!allowedTypes.includes(fileType)) { this.$message.error('只能上传pdf、doc或docx格式的文件'); return false; } if (fileSize > maxFileSize) { this.$message.error(`文件大小超过了${maxFileSize}MB`); return false; } return true; }, downloadTemplate() { // 处理下载模板的逻辑 window.location.href = '/api/download'; }, }, }; </script> ``` 后端(Spring Boot): ```java @RestController @RequestMapping("/api") public class FileController { @PostMapping("/upload") public String uploadFile(@RequestParam("file") MultipartFile file) { // 处理文件上传逻辑 // 可以将上传的文件保存到服务器上的某个目录中 return "上传成功"; } @GetMapping("/download") public void downloadTemplate(HttpServletResponse response) { // 处理文件下载逻辑 // 根据文件名或者其他标识,从服务器上读取相应的文件,并将其以流的形式返回给前端 String fileName = "template.docx"; // 下载的文件名 String filePath = "/path/to/template.docx"; // 文件在服务器上的路径 try { File file = new File(filePath); InputStream inputStream = new FileInputStream(file); response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(fileName, "UTF-8")); IOUtils.copy(inputStream, response.getOutputStream()); response.flushBuffer(); } catch (Exception e) { e.printStackTrace(); } } } ``` 这是一个简单的示例,你可以根据自己的需求进行进一步的调整和优化。希望对你有帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值