vue到出excel

安装

复制代码
//npm install exceljs
npm install exceljs@4.0.0 --save
npm install file-saver

<template>
  <button @click="dade66">导出 66</button>
</template>

<script>
import ExcelJS from 'exceljs';
import { saveAs } from 'file-saver';

export default {
  data() {
    return {
      data: [
        { name: '张三', age: 25, gender: '男' },
        { name: '李四', age: 30, gender: '女' },
      ],
    };
  },
  methods: {
    async dade66() {
       const workbook = new ExcelJS.Workbook();
	   const worksheet = workbook.addWorksheet('Sheet1');
	   // 设置表头
	   worksheet.columns = [
		{ header: '姓名', key: 'name' },
		{ header: '年龄', key: 'age' },
		{ header: '性别', key: 'gender' },
	   ];
	   // 添加数据
	   this.data.forEach(item => {
		worksheet.addRow({ name: item.name, age: item.age, gender: item.gender });
	   });
	   // 生成 Excel 文件并保存
	   await workbook.xlsx.writeBuffer().then(buffer => {
		const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });
		saveAs(blob, 'exported_data.xlsx');
	   });
    },
  },
};
</script>

复制代码
<template>
  <button @click="dade66">导出 66</button>
</template>

<script>
// npm install exceljs
// npm install file-saver
import ExcelJS from 'exceljs';
import { saveAs } from 'file-saver';

export default {
  data() {
    return {
      data: [
        { name: '张三', age: 25, gender: '男' },
        { name: '李四', age: 30, gender: '女' },
      ],
    };
  },
  methods: {
    async dade66() {
        const workbook = new ExcelJS.Workbook();
	    const worksheet = workbook.addWorksheet('Sheet1');
	    // 设置表头
	    worksheet.columns = [
		 { header: '姓名', key: 'name' },
		 { header: '年龄', key: 'age' },
		 { header: '性别', key: 'gender' },
	    ];
	    // 添加数据
	    this.data.forEach(item => {
		 worksheet.addRow({ name: item.name, age: item.age, gender: item.gender });
	    });
	   
	   
	    // 冻结表头(第一行)
		worksheet.views = [{state: 'frozen',ySplit: 1}];
		
	    // 设置列宽
	    worksheet.getColumn(1).width = 15; // 假设设置第一列(姓名列)宽度为 15
	    worksheet.getColumn(2).width = 10; // 假设设置第二列(年龄列)宽度为 10
	    worksheet.getColumn(3).width = 10; // 假设设置第三列(性别列)宽度为 10
	   
	    // 设置行高
		worksheet.getRow(1).height = 18; // 设置第一行(表头行)高度为 25
		worksheet.eachRow((row, rowNumber) => {
		   if (rowNumber > 1) {
			 row.height = 18; // 设置数据行高度为 20
		   }
		});
		
	    // 设置居中对齐
		for (let rowNumber = 1; rowNumber <= worksheet.rowCount; rowNumber++) {
			const row = worksheet.getRow(rowNumber);
			for (let columnNumber = 1; columnNumber <= worksheet.columnCount; columnNumber++) {
			  const cell = row.getCell(columnNumber);
			  cell.alignment = { vertical: 'middle', horizontal: 'center' };
			}
		}
		
		// 合并单元格
		worksheet.mergeCells('A5:C5'); // 合并第一行的 A 到 C 列
		worksheet.mergeCells('A6:C7'); // 跨行合并
	   
	    // 生成 Excel 文件并保存
	    await workbook.xlsx.writeBuffer().then(buffer => {
		 const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });
		 saveAs(blob, 'exported_data.xlsx');
	    });
    },
  },
};
</script>
相关推荐
戌中横18 小时前
JavaScript 对象
java·开发语言·javascript
多仔ヾ18 小时前
Vue.js 前端开发实战之 06-Vue 路由
vue.js
E_ICEBLUE19 小时前
Excel vs CSV:在系统数据处理中该如何选择?
java·excel·csv·格式转换
meng半颗糖19 小时前
vue3+tpescript 点击按钮跳转新页面直接通过链接预览word
前端·vue.js·word
击败不可能19 小时前
vue做任务工具方法的实现
前端·javascript·vue.js
【赫兹威客】浩哥20 小时前
【赫兹威客】框架模板-前端bat脚本部署教程
前端·vue.js
爱上妖精的尾巴20 小时前
7-13 WPS JS宏 this 用构造函数自定义类-2,调用内部对象必须用this
开发语言·javascript·wps·jsa
一 乐20 小时前
学生宿舍管理|基于springboot + vue学生宿舍管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·助农电商系统
bin915320 小时前
(文后附完整代码)html+css+javascript 弓箭射击游戏项目分析
前端·javascript·css·游戏·html·前端开发
qq_4061761421 小时前
深入剖析JS中的XSS与CSRF漏洞:原理、攻击与防御全指南
服务器·开发语言·前端·javascript