JS 将数据保存为 Excel(xls、xlsx)文件,支持单元格样式,合并单元格

简介: JS 将数据保存为 Excel(xls、xlsx)文件,支持单元格样式,合并单元格

一、简介

二、 DZMExcelDownload 使用

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <!-- 导入组件 -->
  <script src="./dzm-download-excel.js"></script>
  <!-- 使用 -->
  <script>
    // 服务器获取到的数据源
    const dataSource = [
      {
        id: 1,
        name: 'dzm',
        // (可选)如果列表数据有子列表数据,也是支持的
        children: [
          {
            id: 4,
            name: 'dzm4',
            children: [
              {
                id: 6,
                name: 'dzm6'
              },
              {
                id: 7,
                name: 'dzm7'
              }
            ]
          },
          {
            id: 5,
            name: 'dzm5',
            // 多层级取值展示到 excel
            info: {
              age: 10
            }
          }
        ]
      },
      {
        id: 2,
        name: 'dzm2',
        // 字符串日期格式,如果需要导出为 Excel 日期格式需要拦截修改类型
        // 格式支持 xxxx/xx/xx、xxxx-xx-xx、xxxx~xx~xx、xxxx年xx月xx日
        birthday: '2015/12/20'
      },
      {
        id: 3,
        name: 'djy'
      }
    ]
    // Excel 每一列的列头名字跟字段key,通过列名展示,列key获取数据源中对应的值作为单元格的值
    const columns = [
      {
        name: '用户ID',
        field: 'id',
        // (可选)单元格样式
        style: {
          // (可选)列宽,一列多行单元格,固定取每列的 0 行位置单元格列宽,目前与横向合并单元格存在定位冲突,也就是暂时不支持横向合并单元格时使用列宽属性(单位:磅)
          colWidth: 100,
        }
      },
      {
        name: '用户名称',
        field: 'name'
        // (可选)单元格样式
        // style: {
        //   // (可选)样式属性是否支持标题使用,默认 false
        //   supportTitle: true,
        //   // (可选)字体颜色
        //   color: '#00ff00',
        //   // (可选)字体大小
        //   fontSize: 12,
        //   // (可选)字体名称
        //   fontName: '宋体',
        //   // (可选)字体加粗:0 | 1
        //   fontBold: 1,
        //   // (可选)内容横向排版:Left、Center、Right
        //   alignmentHor: 'Center',
        //   // (可选)内容竖向排版:Top、Center、Bottom
        //   alignmentVer: 'Center',
        //   // (可选)背景颜色
        //   backgroundColor: '#FF0000',
        //   // (可选)行高,一行多列单元格,会取有行高值的最后一列使用,所以只要行高一样,可任意在一列设置行高,如果值不一样以最后有值的一列为准(单位:磅)
        //   // rowHeight: 100,
        //   // (可选)列宽,一列多行单元格,固定取每列的 0 行位置单元格列宽,目前与横向合并单元格存在定位冲突,也就是暂时不支持横向合并单元格时使用列宽属性(单位:磅)
        //   // colWidth: 100,
        //   // (可选)单元格边框颜色
        //   // 支持空格分开进行单边设置 borderColor: '#00ff00 #00ff00 #00ff00 #00ff00',如果进行单边设置,没设置的边不显示,默认 #000000
        //   borderColor: '#00ff00',
        //   // (可选)单元格边框宽度
        //   // 支持空格分开进行单边设置 borderWidth: '1 2 1 2',如果进行单边设置,没设置的边不显示
        //   borderWidth: 1,
        //   // (可选)单元格边框显示位置:Left、Top、Right、Bottom
        //   // 支持空格分开进行单边设置 borderPosition: 'Left Top Right Bottom',支持空格分开进行单边设置,没设置的边不显示,默认:(空 || '' === borderPosition: 'Left Top Right Bottom')
        //   borderPosition: '',
        //   // (可选)单元格边框样式:Continuous、Dash、Dot、DashDot、DashDotDot、Double,默认 Continuous
        //   // 支持空格分开进行单边设置 borderStyle: 'Continuous Dash Dot DashDot',如果进行单边设置,没设置的边不显示
        //   borderStyle: 'Continuous',
        //   // (可选)合并单元格列表(row 不传则为每行,也可以放到数组底部,作为通用行使用,如果放到数组第0位,会直接使用这个通用样式,后面的样式不会在被使用上)
        //   merges:[
        //     {
        //       // (可选)合并单元格从该字段这一列的第几行开始,索引从 0 开始,不传则为每行,为该列通用行
        //       row: 1,
        //       // (可选)横向合并几列单元格,默认 0 也就是自身
        //       // hor: 2,
        //       // (可选)竖向合并几行单元格,默认 0 也就是自身
        //       ver: 1
        //     },
        //     {
        //       // 通用合并模板:相当于所有没有指定 row 的行都使用通用合并模板
        //       // (可选)合并单元格从该字段这一列的第几行开始,索引从 0 开始,不传则为每行
        //       // row: 3
        //       // (可选)横向合并几列单元格,默认 0 也就是自身
        //       // hor: 3
        //       // (可选)竖向合并几行单元格,默认 0 也就是自身
        //       // ver: 1
        //     }
        //   ]
        // }
      },
      {
        name: '用户年龄',
        // 多层级取值展示到 excel
        // 例如:{ id: 1, info: { age: 10 } }  = 'info.age'
        // 例如:{ id: 1, info: { detail: { age: 10 } } }  = 'info.detail.age'
        field: 'info.age'
      },
      {
        name: '生日',
        field: 'birthday',
        // 也可以这里指定类型,也可以通过 beforeChange 拦截设定类型
        dataType: 'Date'
      }
    ]
    // 将要保存的 sheets 数据源
    const sheets = [
      {
        // 单个 sheet 名字
        name: '用户数据1',
        // 单个 sheet 数据源
        data: dataSource,
        // 单个 sheet 列名称与读取key
        columns: columns
      },
      {
        // 单个 sheet 名字
        name: '用户数据2',
        // 单个 sheet 数据源
        data: dataSource,
        // 单个 sheet 列名称与读取key
        columns: columns
      }
    ]
    // 开始下载
    EXDownloadManager(sheets, function (item, field, json, sheetIndex, row, col, columnCount, rowCount) {
       // index: 第几个sheet,row: 第几行,col: 第几列,columnCount: 当前 sheet 总列数,rowCount: 当前 sheet 总行数
      // item: 单元格数据 field: 字段名 json: 当前单元格数据源对象
      // 判断处理单个字段
      // 单元格内容:item.data
      // 单元格类型:item.dataType(默认空,会自动识别,有值会优先使用指定类型)
      // 单元格数据源:json
      // console.log(item, item.data, item.dataType, field, json, sheetIndex, row, col, columnCount, rowCount);
      // 拦截修改样式 - 随机背景
      item.style.backgroundColor = GetRandomColor()
      item.style.color = GetRandomColor()
      item.style.borderColor = GetRandomColor()
      // 合并位置处理
      if (row === 0) {
        // (可选)内容横向排版:Left、Center、Right
        item.style.alignmentHor = 'Center'
        // (可选)内容竖向排版:Top、Center、Bottom
        item.style.alignmentVer = 'Center'
        // (可选)行高
        item.style.rowHeight = 40
        // 定义合并样式
        item.style.merges = [{
          // (可选)合并单元格从该字段这一列的第几行开始,索引从 0 开始
          row: row,
          // (可选)横向合并几列单元格,默认 0 也就是自身,使用该参数 row 为必填
          hor: 7
          // (可选)竖向合并几行单元格,默认 0 也就是自身,使用该参数 row 为必填
          // ver: 3
        }]
      }
      // 如果需要单独处理数据
      // item.data = '调整之后的新数据'
      // item.dataType = 'Boolean'
      // 将日期字符串改为 Excel 日期格式
      // if (field === 'birthday') {
      //   item.dataType = 'Date'
      // }
      // 返回处理好的值
      if (row === 0) {
        // 0 行 0 列返回显示,0 行其他列不返回,因为 0 行 0 列有合并单元格操作
        if (col === 0) { return item
        } else { return null }
      }
      // 其他行列正常返回
      return item
    })
    // 随机颜色
    function GetRandomColor () {
      var tags = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f']
      var color = '#'
      for (var i = 0; i < 6; i++) {
        color += tags[Math.floor(Math.random() * tags.length)]
      }
      return color
    }
  </script>
</body>
</html>
相关文章
|
23天前
|
JavaScript API
深入探索fs.WriteStream:Node.js文件写入流的全面解析
深入探索fs.WriteStream:Node.js文件写入流的全面解析
|
7天前
|
存储 JSON JavaScript
学习node.js十三,文件的上传于下载
学习node.js十三,文件的上传于下载
|
1月前
|
前端开发 JavaScript
使用Vue+xlsx+xlsx-style实现导出自定义样式的Excel文件
本文介绍了在Vue项目中使用`xlsx`和`xlsx-style`(或`xlsx-style-vite`)库实现导出具有自定义样式的Excel文件的方法,并提供了详细的示例代码和操作效果截图。
271 1
使用Vue+xlsx+xlsx-style实现导出自定义样式的Excel文件
|
1月前
|
前端开发 Python
使用Python+openpyxl实现导出自定义样式的Excel文件
本文介绍了如何使用Python的openpyxl库导出具有自定义样式的Excel文件,包括设置字体、对齐方式、行列宽高、边框和填充等样式,并提供了完整的示例代码和运行效果截图。
28 1
使用Python+openpyxl实现导出自定义样式的Excel文件
|
1月前
|
JavaScript 数据安全/隐私保护
如何在Vue组件中调用封装好的外部js文件方法
这篇文章介绍了如何在Vue组件中调用封装好的外部js文件方法,包括在Vue项目中全局引入外部js文件,并在组件中通过this.$myMethod()的方式调用外部js文件中定义的方法。
如何在Vue组件中调用封装好的外部js文件方法
|
26天前
|
前端开发 JavaScript Linux
【Azure 应用服务】在Azure App Service for Linux环境中,部署的Django应用,出现加载css、js等静态资源文件失败
【Azure 应用服务】在Azure App Service for Linux环境中,部署的Django应用,出现加载css、js等静态资源文件失败
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
70 2
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
63 4
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
55 4
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的大学生入伍人员管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的大学生入伍人员管理系统附带文章源码部署视频讲解等
67 4