700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 封装vue导出excel组件(扩展嵌入图片 操作工作表 表格样式等功能)

封装vue导出excel组件(扩展嵌入图片 操作工作表 表格样式等功能)

时间:2021-02-14 12:46:44

相关推荐

封装vue导出excel组件(扩展嵌入图片 操作工作表 表格样式等功能)

导出的excel中嵌入图片,同时还需要操作多个工作表与表格样式,看了一些java的插件不太适合,因为我这边的需求是动态表单,字段不固定。后端的插件大部分依赖实体类注解,要不就是操作比较繁琐。又看了一些Vue导出excel的插件。大部分功能不全,不满足手里的需求。

无意中发现了Excel.js这个工具功能还是比较全,我在他的基础上做了二次封装。方便了数据的传入、格式的设置。其实还有很多功能是可以扩展的,后期再完善吧。

目前已实现功能:1、可以增加工作表2、可以指定图片列,并嵌入图片3、指定头部样式

1、先下载依赖:cnpm install exceljs file-saver -S;

2、使用说明:

## 自定义封装的Excel导出,支持增加工作表、嵌入图片 =======@杨华--_01_10==========## 基于exceljs二次封装,支持exceljs的所有接口## cnpm install exceljs file-saver -S;<!-- 格式要求 --># 标题行let column = [{title: '维修内容', key: '维修内容',type: 'text'},{title: '维修图',key: '维修图',type: 'image',width: 200,height: 250}]# 内容格式--ps:键需与标题行的key一致let data = [{'维修内容': '维修EPS','维修图': 'http://url/name.jpg',}]# 使用教程1、import {createWorkBook,exportStatics,downloadWorkBook} from "@/utils/Excel/excel.js";2、# 创建工作簿let workbook = createWorkBook();//初始化基本属性# 创建工作表,可多次创建let worksheet = workbook.addWorksheet('自定义工作表名');workbook = await exportStatics(workbook,worksheet,column,data); # 下载ExceldownloadWorkBook(workbook,'自定义文件名');

3、封装代码如下:

import Excel from "exceljs";import * as FileSaver from "file-saver";//用于客户端读写数据// 传入工作簿、工作表、表头、数据。export function exportStatics(workbook,worksheet,heard,tableData) {// 一、创建工作簿// let workbook = new Excel.Workbook();// setWorkbook(workbook);//初始化基本属性// 二、创建工作表// let worksheet = workbook.addWorksheet("sheet1");// 表头===================================================================================handleTitle(worksheet,heard);// 插入表格内容数据================================================================================handleContent(worksheet,heard,tableData);// 处理图片==================================================================================await handleImage(workbook,worksheet,heard,tableData);return workbook;};// 处理表头===========================function handleTitle(worksheet,heard){// const listHearder = Object.keys(heard);// 按行的格式插入表头worksheet.insertRow(1,// 行的位置heard.map(item =>{ return item.title; })//表头组成的数组);// =====设置样式=====//设置标题行的填充颜色,此处可扩展worksheet.getRow(1).fill = {type: 'pattern',pattern:'darkTrellis',fgColor:{argb:'EDEDED'},bgColor:{argb:'EDEDED'}};//设置行居中 worksheet.getRow(1).height =25;//设置行高度---下标从1开始;worksheet.getRow(1).alignment = { vertical: 'middle', horizontal: 'center' }; }// 处理数据内容=======================function handleContent(worksheet,heard,tableData){tableData.forEach((item, index) => {worksheet.insertRow(index + 2,//从第二行开始插入heard.map((ite) => {if(ite.type && ite.type != 'image'){return item[ite.key]}else{return "";}}));});}// 处理图片async function handleImage(workbook,worksheet,heard,tableData){let width = 200,height = 250;// 首先拿到格式为图片的列let column = heard.filter((item,index)=>{return item.type == 'image'})if(column!=null && column.length>0){let ImageTitle = {};//存放type为image的标题行column.forEach(element => {ImageTitle[element.title] = element;});for(let index = 0,len=tableData.length; index < len; index++) {// index代表行,column代表列let item = tableData[index];let column = 0for(let key in item){if(ImageTitle[key]){width = ImageTitle[key].width?ImageTitle[key].width:width;height = ImageTitle[key].height?ImageTitle[key].height:height;if(item[key]){let mbase64 = await imgUrlToBase64(item[key]);//将图片转为base64格式if(mbase64){const imageId1 = workbook.addImage({base64: mbase64,extension: "png",// 图片扩展名,支持“jpeg”,“png”,“gif”});worksheet.addImage(imageId1, {tl: { col: column, row: index+1 },//这个下标是从0开始ext: { width: width, height: height },//图片的宽与高hyperlinks: {hyperlink: item[key],tooltip: item[key]}});worksheet.getColumn(column+1).width = width/8;//设置列宽度---这个下标是从1开始;worksheet.getRow(index+2).height = height/1.25;//设置行高度---下标从1开始;}}}worksheet.getRow(index+2).alignment = { vertical: 'middle', horizontal: 'center' };//设置行居中column++;}}}debugger}// 将图片转为base64格式-------function imgUrlToBase64(url) {// 加载失败默认显示let fail = ''return new Promise((resolve, reject) => {if (!url) {reject('请传入url内容')}if (/\.(png|jpe?g|gif|svg)(\?.*)?$/.test(url)) {// 图片地址const image = new Image()// 设置跨域问题image.setAttribute('crossOrigin', 'anonymous')// 图片地址image.src = urltry{image.onload = () => {const canvas = document.createElement('canvas')const ctx = canvas.getContext('2d')canvas.width = image.widthcanvas.height = image.heightctx.drawImage(image, 0, 0, image.width, image.height)// 获取图片后缀const ext = url.substring(url.lastIndexOf('.') + 1).toLowerCase()// 转base64const dataUrl = canvas.toDataURL(`image/${ext}`)resolve(dataUrl || '')}image.onerror = () =>{resolve(fail);}}catch(e){resolve(fail);}} else {// 非图片地址reject(fail);}})};//导出表格下载方法=================================================================================export function downloadWorkBook(workbook,name){name = name?name:'download';const EXCEL_TYPE ="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8";workbook.xlsx.writeBuffer().then((data) => {const blob = new Blob([data], { type: EXCEL_TYPE });console.log(blob.stream(), 6664744)FileSaver.saveAs(blob, name+".xlsx");});}//创建workBook实例export function createWorkBook(){let workbook = new Excel.Workbook()setWorkbook(workbook);return workbook;}// 设置工作簿的基本属性export function setWorkbook(workbook){// 设置工作簿的属性workbook.creator = "Me";workbook.lastModifiedBy = "Her";workbook.created = new Date(1985, 8, 30);workbook.modified = new Date();workbook.lastPrinted = new Date();// 工作簿视图,工作簿视图控制在查看工作簿时 Excel 将打开多少个单独的窗口workbook.views = [{x: 0,y: 0,width: 1000,height: 2000,firstSheet: 0,activeTab: 0,visibility: "visible",horizontalCentered:true},];}

3、导出效果

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。