vue使用docx 生成 导出word文件。(包含:页眉、页脚、生成目录、页码、图片、表格、合并表格)

docx官网

一:安装

javascript 复制代码
npm install --save docx

二:docx.vue

javascript 复制代码
<template>
  <div class="">
    <el-button type="primary" @click="downloadDocx">下载DOCX</el-button>
  </div>
</template>

<script>
import { docxConfig } from "@/utils/docx";
import { Packer } from "docx";
import { downloadFile } from "@/utils/index";
export default {
  name: "docx",

  props: {},

  components: {},

  data () {
    return {
        docxList: {
            year: '2025年',
            month: '5月',
            table1Data: {
                widthList: [750, 4500, 3000, 750],
                list: [{
                    value: ['序号', '管养单位', '管养路线', '备注']
                }, {
                    value: ['1', '山东高速集团有限公司', 'G0321、G15、G1511、G18、G1813、G1815、G2、G20、G2001、G22、G25、G2516、G35、G3511', '']
                }, {
                    value: ['2', '东营黄河大桥有限公司', 'G18', '']
                }, {
                    value: ['3', '青岛城市建设投资(集团)有限责任公司', 'G22', '']
                }, {
                    value: ['4', '青岛市公路事业发展中心', 'G15、G20、G2011', '']
                }, {
                    value: ['5', '山东大钿蒂黄河大桥建设投资有限公司', 'G3511', '']
                }, {
                    value: ['6', '山东葛洲坝巨单高速公路有限公司', 'G0321', '']
                }, {
                    value: ['7', '山东鄄城黄河公路大桥投资有限公司', 'G0321', '']
                }, {
                    value: ['8', '山东秦滨高速公路建设有限公司', 'G0111', '']
                }, {
                    value: ['9', '山东省金鲁班德商高速公路发展有限公司', 'G0321', '']
                }, {
                    value: ['10', '中铁菏泽德商高速公路建设发展有限公司', 'G35', '']
                }, {
                    value: ['11', '中铁建(山东)德商高速公路有限公司', 'G0321', '']
                }, {
                    value: ['12', '中铁建山东京沪高速公路济乐有限公司', 'G2', '']
                }
                ]
            },
            table2Data: {
                widthList: [3000, 3000, 3000],
                list: [{
                    value: ['wtur', 'wtuf', 'wtud']
                }, {
                    value: ['0.6', '0.2', '0.2']
                }]
            },
            table3Data: {
                widthList: [1800, 1800, 1800, 1800, 1800],
                list: [{
                    value: ['技术状况等级', '1类', '2类', '3类', '4类']
                }, {
                    value: ['技术状况得分', 'Stu≥90', '80≤Stu<90', '70≤Stu<80', 'Stu<70']
                }]
            },
            table4Data: {
                widthList: [2500, 6500],
                list: [{
                    value: ['技术状况评定等级', '养护建议']
                }, {
                    value: ['1类', '分项工程运行正常,正常养护。']
                }, {
                    value: ['2类', '分项工程存在非关键项问题,但不影响系统主要功能实现,需要加大养护频次,同时注意备品备件是否齐全。']
                }, {
                    value: ['3类', '分项工程较多的非关键功能或有少量关键项存在问题,需对问题进行针对性分析,制定维修或设备更换养护策略。']
                }, {
                    value: ['4类', '分项工程非关键功能项存在问题较多,或者关键项存在问题无法修复,或者其性能虽然满足行业普遍要求,但无法满足业主方使用需要,需对问题进行针对性分析,制定设备更换或专项升级改造养护策略。']
                }]
            },
            tunnelTotalNum: '0',
            table5Data: {
                hasHeader: true,
                columnWidths: [750, 1275, 1275, 2250, 1125, 1125, 1200],
                list: []
            },
            table6Data: {
                widthList: [752, 2062, 2062, 2062, 2062],
                list: []
            },
            table7DataHeader: {
                columnWidths: [750, 1275, 1275, 2250, 3450],
                list: [['序号', '隧道名称', '分部设施', '分项设施', '技术状况评定结果']]
            },
            table7Data: {
                hasHeader: false,
                columnWidths: [750, 1275, 1275, 2250, 1725, 1725],
                list: []
            },
            needMaintain: '0',
            totalMaintainFee: '0'
        },
        mergeData: {
            tunnelNameMerge: [],
            projectNameMerge: [],
            tunnelNameMerge2: [],
            projectNameMerge2: [],
            itemProjectNameMerge2: []
        }
    };
  },

  computed: {},

  watch: {},
  created () { },

  mounted () { },

  methods: {
    // 导出docx - 已解决 Microsoft Word 打开会报错版本
    downloadDocx () {
        let res={
            "msg": "操作成功",
            "code": 200,
            "data": {
            "detail_list": [
                {
                    "tunnel_id": 306,
                    "tunnel_name": "上游隧道",
                    "tunnel_part_project_id": 187,
                    "tunnel_part_project_name": "供配电设施",
                    "tunnel_item_project_id": 9105,
                    "tunnel_item_project_name": "综合微机保护装置",
                    "tunnel_item_project_score": 54.44,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 306,
                    "tunnel_name": "上游隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9129,
                    "tunnel_item_project_name": "紧急电话",
                    "tunnel_item_project_score": 57.43,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 306,
                    "tunnel_name": "上游隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9130,
                    "tunnel_item_project_name": "广播",
                    "tunnel_item_project_score": 47.52,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9121,
                    "tunnel_item_project_name": "亮度检测器",
                    "tunnel_item_project_score": 60.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9136,
                    "tunnel_item_project_name": "能见度检测器",
                    "tunnel_item_project_score": 60.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9123,
                    "tunnel_item_project_name": "CO检测器",
                    "tunnel_item_project_score": 54.55,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9124,
                    "tunnel_item_project_name": "风速风向检测器",
                    "tunnel_item_project_score": 54.55,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9125,
                    "tunnel_item_project_name": "车辆检测器",
                    "tunnel_item_project_score": 50.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9126,
                    "tunnel_item_project_name": "闭路电视监控设施",
                    "tunnel_item_project_score": 65.33,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9127,
                    "tunnel_item_project_name": "视频事件检测器",
                    "tunnel_item_project_score": 60.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 362,
                    "tunnel_name": "大瓮山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9134,
                    "tunnel_item_project_name": "监控室设备及系统",
                    "tunnel_item_project_score": 66.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 304,
                    "tunnel_name": "大龙堂隧道",
                    "tunnel_part_project_id": 188,
                    "tunnel_part_project_name": "照明设施",
                    "tunnel_item_project_id": 9110,
                    "tunnel_item_project_name": "隧道灯具",
                    "tunnel_item_project_score": 35.71,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 304,
                    "tunnel_name": "大龙堂隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9121,
                    "tunnel_item_project_name": "亮度检测器",
                    "tunnel_item_project_score": 0.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 304,
                    "tunnel_name": "大龙堂隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9134,
                    "tunnel_item_project_name": "监控室设备及系统",
                    "tunnel_item_project_score": 37.50,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 424,
                    "tunnel_name": "寨山隧道",
                    "tunnel_part_project_id": 186,
                    "tunnel_part_project_name": "消防设施",
                    "tunnel_item_project_id": 9113,
                    "tunnel_item_project_name": "火灾自动探测报警系统",
                    "tunnel_item_project_score": 66.29,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 424,
                    "tunnel_name": "寨山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9132,
                    "tunnel_item_project_name": "交通控制和诱导设施",
                    "tunnel_item_project_score": 0.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 424,
                    "tunnel_name": "寨山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9134,
                    "tunnel_item_project_name": "监控室设备及系统",
                    "tunnel_item_project_score": 68.75,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 422,
                    "tunnel_name": "柿子峪隧道",
                    "tunnel_part_project_id": 187,
                    "tunnel_part_project_name": "供配电设施",
                    "tunnel_item_project_id": 9101,
                    "tunnel_item_project_name": "电力电容器柜",
                    "tunnel_item_project_score": 50.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 422,
                    "tunnel_name": "柿子峪隧道",
                    "tunnel_part_project_id": 186,
                    "tunnel_part_project_name": "消防设施",
                    "tunnel_item_project_id": 9113,
                    "tunnel_item_project_name": "火灾自动探测报警系统",
                    "tunnel_item_project_score": 65.84,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 422,
                    "tunnel_name": "柿子峪隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9125,
                    "tunnel_item_project_name": "车辆检测器",
                    "tunnel_item_project_score": 50.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 422,
                    "tunnel_name": "柿子峪隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9134,
                    "tunnel_item_project_name": "监控室设备及系统",
                    "tunnel_item_project_score": 68.75,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 423,
                    "tunnel_name": "蟠龙山隧道",
                    "tunnel_part_project_id": 186,
                    "tunnel_part_project_name": "消防设施",
                    "tunnel_item_project_id": 9113,
                    "tunnel_item_project_name": "火灾自动探测报警系统",
                    "tunnel_item_project_score": 68.52,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 423,
                    "tunnel_name": "蟠龙山隧道",
                    "tunnel_part_project_id": 186,
                    "tunnel_part_project_name": "消防设施",
                    "tunnel_item_project_id": 9120,
                    "tunnel_item_project_name": "给水管与阀门",
                    "tunnel_item_project_score": 66.67,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 423,
                    "tunnel_name": "蟠龙山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9125,
                    "tunnel_item_project_name": "车辆检测器",
                    "tunnel_item_project_score": 50.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 423,
                    "tunnel_name": "蟠龙山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9134,
                    "tunnel_item_project_name": "监控室设备及系统",
                    "tunnel_item_project_score": 68.75,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 302,
                    "tunnel_name": "蟠龙隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9136,
                    "tunnel_item_project_name": "能见度检测器",
                    "tunnel_item_project_score": 52.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 260,
                    "tunnel_name": "西山寨隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9127,
                    "tunnel_item_project_name": "视频事件检测器",
                    "tunnel_item_project_score": 60.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 260,
                    "tunnel_name": "西山寨隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9135,
                    "tunnel_item_project_name": "软件应急方案",
                    "tunnel_item_project_score": 0.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 259,
                    "tunnel_name": "青龙山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9127,
                    "tunnel_item_project_name": "视频事件检测器",
                    "tunnel_item_project_score": 60.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 259,
                    "tunnel_name": "青龙山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9135,
                    "tunnel_item_project_name": "软件应急方案",
                    "tunnel_item_project_score": 0.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 258,
                    "tunnel_name": "马山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9121,
                    "tunnel_item_project_name": "亮度检测器",
                    "tunnel_item_project_score": 65.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 258,
                    "tunnel_name": "马山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9127,
                    "tunnel_item_project_name": "视频事件检测器",
                    "tunnel_item_project_score": 60.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                },
                {
                    "tunnel_id": 258,
                    "tunnel_name": "马山隧道",
                    "tunnel_part_project_id": 185,
                    "tunnel_part_project_name": "监控与通信设施",
                    "tunnel_item_project_id": 9135,
                    "tunnel_item_project_name": "软件应急方案",
                    "tunnel_item_project_score": 0.00,
                    "tunnel_item_project_level": "4",
                    "detection_date": "2024",
                    "quantities": 0,
                    "estimated_fee": 0.0
                }
            ],
                "need_maintain": 10,
                "summary_list": [
                {
                    "tunnel_name": "大瓮山隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G1815",
                    "remark": "潍日高速"
                },
                {
                    "tunnel_name": "上游隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G2",
                    "remark": "京沪高速"
                },
                {
                    "tunnel_name": "大龙堂隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G2",
                    "remark": "京沪高速"
                },
                {
                    "tunnel_name": "蟠龙隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G2",
                    "remark": "京沪高速"
                },
                {
                    "tunnel_name": "寨山隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G22",
                    "remark": "青兰高速"
                },
                {
                    "tunnel_name": "柿子峪隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G22",
                    "remark": "青兰高速"
                },
                {
                    "tunnel_name": "蟠龙山隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G22",
                    "remark": "青兰高速"
                },
                {
                    "tunnel_name": "马山隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G9911",
                    "remark": "济南都市圈环线"
                },
                {
                    "tunnel_name": "西山寨隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G9911",
                    "remark": "济南都市圈环线"
                },
                {
                    "tunnel_name": "青龙山隧道",
                    "maintain_fee": 0.0,
                    "road_code": "G9911",
                    "remark": "济南都市圈环线"
                }
            ],
                "total_maintain_fee": 0.0
        }
        }
        if (res.code == 200) {
            let { detail_list = [], summary_list = [], total_maintain_fee, need_maintain } = res.data || {}
            this.mergeHandle('tunnel_name', 'tunnelNameMerge', detail_list)
            this.mergeHandle('tunnel_part_project_name', 'projectNameMerge', detail_list)
            let { tunnelNameMerge = [], projectNameMerge = [] } = this.mergeData
            let table5DataList = [
                {
                    row: [{
                        text: '序号'
                    }, {
                        text: '隧道名称'
                    }, {
                        text: '分部设施'
                    }, {
                        text: '分项设施'
                    }, {
                        text: '单位'
                    }, {
                        text: '工程量'
                    }, {
                        text: '估算(万元)'
                    }]
                }
            ], idx = 1
            let detail_list7 = []
            detail_list.forEach((item, index) => {
                detail_list7.push({ ...item, resType: '得分' }, { ...item, resType: '类别' })
                let rowObj = {
                    row: []
                }
                if (tunnelNameMerge[index] != 0) {
                    rowObj.row.push({
                        text: idx + '',
                        rowSpan: tunnelNameMerge[index]
                    }, {
                        text: item.tunnel_name,
                        rowSpan: tunnelNameMerge[index]
                    })
                    idx++
                }
                if (projectNameMerge[index] != 0) {
                    rowObj.row.push({
                        text: item.tunnel_part_project_name,
                        rowSpan: projectNameMerge[index]
                    })
                }
                rowObj.row.push(
                    {
                        text: item.tunnel_item_project_name
                    }, {
                        text: '套'
                    }, {
                        text: item.quantities + ''
                    }, {
                        text: item.estimated_fee + ''
                    }
                )
                table5DataList.push(rowObj)
            })
            this.docxList.table5Data.list = table5DataList
            this.docxList.tunnelTotalNum = (idx-1) + ''
            /*---------------最后一个表开始-------------------*/
            let table7DataList = [], table7Idx = 1
            this.mergeHandle('tunnel_name', 'tunnelNameMerge2', detail_list7)
            this.mergeHandle('tunnel_part_project_name', 'projectNameMerge2', detail_list7)
            this.mergeHandle('tunnel_item_project_name', 'itemProjectNameMerge2', detail_list7)
            let { tunnelNameMerge2 = [], projectNameMerge2 = [], itemProjectNameMerge2 = [] } = this.mergeData
            detail_list7.forEach((item, index) => {
                let rowObj = {
                    row: []
                }
                if (tunnelNameMerge2[index] != 0) {
                    rowObj.row.push({
                        text: table7Idx + '',
                        rowSpan: tunnelNameMerge2[index]
                    }, {
                        text: item.tunnel_name,
                        rowSpan: tunnelNameMerge2[index]
                    })
                    table7Idx++
                }
                if (projectNameMerge2[index] != 0) {
                    rowObj.row.push({
                        text: item.tunnel_part_project_name,
                        rowSpan: projectNameMerge2[index]
                    })
                }
                if (itemProjectNameMerge2[index] != 0) {
                    rowObj.row.push({
                        text: item.tunnel_item_project_name,
                        rowSpan: itemProjectNameMerge2[index]
                    })
                }
                rowObj.row.push(
                    {
                        text: item.resType
                    }, {
                        text: item.resType == '得分' ? item.tunnel_item_project_score + '' : item.tunnel_item_project_level
                    }
                )
                table7DataList.push(rowObj)
            })
            this.docxList.table7Data.list = table7DataList
            /*---------------最后一个表结束-------------------*/

            /*--------------表3-2各隧道决策推荐计划汇总(倒数第二个表)-----------*/
            let table6DataList = [{
                value: ['序号', '隧道名称', '高速名称', '估算(万元)', '备注']
            }]

            summary_list.forEach((item, index) => {
                table6DataList.push({
                    value: [
                        index + 1 + '',
                        item.tunnel_name,
                        item.road_code,
                        item.maintain_fee + '',
                        item.remark
                    ]
                })
            })
            table6DataList.push({
                value: [
                    '合计',
                    '',
                    '',
                    total_maintain_fee + '',
                    ''
                ]
            })
            this.docxList.table6Data.list = table6DataList
            this.docxList.totalMaintainFee = total_maintain_fee + ''
            this.docxList.needMaintain = need_maintain + ''
            this.docxList.year=this.curyear+"年"
            let currentDate = new Date();
            let currentMonth = currentDate.getMonth() + 1;
            this.docxList.month=currentMonth+"月"
            // 创建实例
            const docx = new docxConfig()
            // 调用生成docx方法,并将希望生成值传递进去
            const doc = docx.create(this.docxList)
            // 导出为 Blob - 将文件同步给后端接口
            // Packer.toBlob(doc).then(async (blob) => {
            //   const formData = new FormData();
            //   formData.append("file", blob);
            //   const data = await upload(formData);
            //   downloadFile(blob, "模板");
            // });
            // 直接导出,不留痕
            Packer.toBlob(doc).then((blob) => {
                downloadFile(blob, this.curyear+'年度山东省国家级高速公路隧道机电设施养护决策分析报告')
            })
        }

    },
      // 处理表格合并问题
      mergeHandle(mergeKey, dataKey, list) {
          let mergeList = []
          list.forEach((item, index) => {
              let idx = list.findIndex((t) => t[mergeKey] == item[mergeKey] && t.tunnel_id == item.tunnel_id)
              if (idx == index) {
                  mergeList.push(1)
              } else {
                  mergeList[idx] += 1
                  mergeList.push(0)
              }
          })
          this.mergeData[dataKey] = mergeList
      }

  },
};
</script>

<style scoped lang="less">
</style>

三: docx.js 位置:/utils/docx

javascript 复制代码
import {
    AlignmentType,
    Document,
    TabStopType,
    TabStopPosition,
    Paragraph,
    TextRun,
    Tab,
    Header,
    Footer,
    ImageRun,
    TableCell,
    TableRow,
    Table,
    TableLayoutType,
    VerticalAlign,
    InternalHyperlink,
    Bookmark,
    ExternalHyperlink,
    PageReference,
    HorizontalPositionRelativeFrom,
    HorizontalPositionAlign,
    VerticalPositionRelativeFrom,
    VerticalPositionAlign,
    UnderlineType,
    WidthType,
    PageNumber,
    PageBreak,
    BorderStyle,
    HeadingLevel,
    TableOfContents,
    NumberFormat,
    StyleLevel,
    File
} from 'docx'
import { base64Img1, base64Img2, base64Img3, base64Img4 } from '@/utils/base64Img'

export class docxConfig {
    create(docxList) {
        const doc = new Document({
            features: {
                updateFields: true
            },
            sections: [
                {
                    // 对文档进行全局设置配置
                    properties: {},
                    // 设置内容区域
                    children: [
                        // 主标题
                        this.createText({
                            text: docxList.year + '度山东省国家级高速公路',
                            font: { size: 44, bold: true },
                            alignment: 'center',
                            spacing: { before: 1500, after: 100 }
                        }),
                        this.createText({
                            text: '隧道机电设施养护决策分析报告',
                            font: { size: 44, bold: true },
                            alignment: 'center',
                            spacing: { before: 0, after: 1500 }
                        }),
                        this.createImg({
                            baseImg: base64Img1,
                            width: 550,
                            height: 310,
                            spacing: { after: 3500 },
                            alignment: 'center'
                        }),
                        // 副标题
                        this.createText({
                            text: docxList.year + docxList.month,
                            font: { size: 28 },
                            spacing: { before: 150, after: 150 },
                            alignment: 'center'
                        })
                    ]
                },
                {
                    // 对文档进行全局设置配置
                    properties: {
                        titlePage: true,
                        page: {
                            pageNumbers: {
                                start: 1,
                                formatType: NumberFormat.DECIMAL
                            }
                        }
                    },
                    headers: {
                        default: new Header({
                            children: [
                                new Paragraph({
                                    children: [
                                        new TextRun({
                                            text: docxList.year + '度山东省国家级高速公路隧道机电设施养护决策分析报告',
                                            bold: false,
                                            font: {
                                                name: '宋体'
                                            },
                                            color: '000000',
                                            size: 20
                                        })
                                    ],
                                    border: {
                                        bottom: {
                                            color: 'auto',
                                            space: 1,
                                            style: BorderStyle.DOUBLE,
                                            size: 6
                                        }
                                    },
                                    alignment: 'center'
                                })
                            ],
                            alignment: 'center'
                        }),
                        first: new Header({
                            children: [
                                new Paragraph({
                                    children: [
                                        new TextRun({
                                            text: docxList.year + '度山东省国家级高速公路隧道机电设施养护决策分析报告',
                                            bold: false,
                                            font: {
                                                name: '宋体'
                                            },
                                            color: '000000',
                                            size: 20
                                        })
                                    ],
                                    border: {
                                        bottom: {
                                            color: 'auto',
                                            space: 1,
                                            style: BorderStyle.DOUBLE,
                                            size: 6
                                        }
                                    },
                                    alignment: 'center'
                                })
                            ],
                            alignment: 'center'
                        })
                    },
                    footers: {
                        default: new Footer({
                            children: [
                                new Paragraph({
                                    alignment: 'center',
                                    children: [
                                        new TextRun({
                                            children: [PageNumber.CURRENT]
                                        })
                                    ]
                                })
                            ]
                        }),
                        first: new Footer({
                            children: [
                                new Paragraph({
                                    alignment: 'center',
                                    children: [
                                        new TextRun({
                                            children: [PageNumber.CURRENT]
                                        })
                                    ]
                                })
                            ]
                        })
                    },
                    // 设置内容区域
                    children: [
                        this.createText({
                            text: '目录',
                            font: { size: 32 },
                            alignment: 'center',
                            spacing: { before: 100, after: 200 }
                        }),
                        new TableOfContents('目录', {
                            hyperlink: true,
                            headingStyleRange: '1-5',
                            stylesWithLevels: [new StyleLevel('MySpectacularStyle', 1)]
                        }),
                        // ---- 分页符 -----
                        this.createPageBreakBefore(),
                        this.createText({
                            text: '说明',
                            font: { size: 32 },
                            alignment: 'center',
                            spacing: { before: 100, after: 200 }
                        }),
                        this.createText({ text: '1.通过系统汇集' + (parseInt(docxList.year) - 1) + '年度国家级高速公路隧道基本信息、检查情况、技术状况、养护处治等数据,进行' + docxList.year + '度国家级高速公路隧道养护决策分析。' }),
                        this.createText({ text: '2.隧道技术状况评定和养护决策分析以单座隧道为评定单元,实现项目级分析。' }),
                        this.createText({ text: '3.本报告中的隧道上行指桩号递增方向(右洞),下行指桩号递减方向(左洞)。' }),
                        this.createText({ text: '4.本报告提供的机电设施养护建议可用于开展隧道养护设计工作的依据。' }),

                        this.createPageBreakBefore(),
                        this.createText({
                            text: '一:概况',
                            font: { size: 32 },
                            heading: HeadingLevel.HEADING_1,
                            spacing: { before: 10, after: 150 }
                        }),
                        this.createText({
                            text: '    通过及时了解和全面掌握山东省国家级高速公路隧道技术状况,应用科学的分析手段与方法对隧道基础属性数据、检查数据、交通量数据、养护历史数据进行分析比选,为制定' + docxList.year + '度养护项目计划提供依据。'
                        }),
                        this.createText({
                            text: '    山东省国家级高速公路管养信息如下:'
                        }),
                        this.createText({
                            text: '表1-1山东省国家级高速公路管养单位信息',
                            alignment: 'center'
                        }),
                        this.createTableFor(docxList.table1Data.widthList, {
                            left: 100,
                            top: 20,
                            bottom: 20
                        }, { text: docxList.table1Data.list, alignment: 'left' }),
                        this.createText({
                            text: '二、隧道机电养护决策分析方法',
                            font: { size: 32 },
                            heading: HeadingLevel.HEADING_1,
                            spacing: { before: 200, after: 150 }
                        }),
                        this.createText({
                            text: '2.1基本思路',
                            font: { size: 28 },
                            heading: HeadingLevel.HEADING_2,
                            spacing: { before: 0, after: 100 }
                        }),
                        this.createText({
                            text: '    公路养护决策侧重于路网级决策,隧道机电设施因构成复杂,且数量种类较多,因此公路隧道机电设施养护决策采用项目分级分析,将分部设施分为监控与通信设施、消防设施、供配电设施、通风设施、照明设施五大类。基于' + (parseInt(docxList.year) - 1) + '年隧道机电设施健康状况评定表,筛选出得分较低的分部设施,进而细化得分较低的分项设施,评分主要依据机电设施的设备年限和故障频次,具体策略详见2.2决策步骤,最终确定' + docxList.year + '隧道机电设施养护决策结果。'
                        }),
                        this.createText({
                            text: '    根据' + docxList.year + '隧道机电设施养护决策定结果,对山东省国家级高速公路隧道养护需求进行分析,提出养护工程量及估算建议,形成2024年度决策分析推荐计划。'
                        }),
                        this.createText({
                            text: '2.2决策步骤',
                            font: { size: 28 },
                            heading: HeadingLevel.HEADING_2,
                            spacing: { before: 100, after: 100 }
                        }),
                        this.createText({
                            text: '    1)适用范围',
                            font: { size: 26 },
                            heading: HeadingLevel.HEADING_3,
                            spacing: { before: 100, after: 100 }
                        }),
                        this.createText({
                            text: '    本科学决策方法用于指导集团公司所辖高速公路隧道系统机电设备的技术状况和定期检测的评定,为更新改造的决策的提供数据支撑。'
                        }),
                        this.createText({
                            text: '    本方法中"更新"主要是指因重大变更或设备老化、损坏导致现有机电设备性能指标无法满足工作需求,需要对其进行的分项或整体升级改造。'
                        }),
                        this.createText({
                            text: '    2)更新原则',
                            font: { size: 26 },
                            heading: HeadingLevel.HEADING_3,
                            spacing: { before: 100, after: 100 }
                        }),
                        this.createText({
                            text: '    1.隧道机电设施更新改造应在技术状况评定、定期检测评定、技术发展要求、运营管理需求等综合考虑下,有计划、有重点地进行更新改造。'
                        }),
                        this.createText({
                            text: '    2.隧道机电设施更新改造应根据高速公路机电技术发展的新进展、新成果,着重采用技术更新的方式,改善和提高机电设备技术水平,达到稳定、高效、安全、低耗的综合效果。'
                        }),
                        this.createText({
                            text: '    3.隧道机电设施更新改造应进行技术经济论证,科学决策,选择最优方案,确保获得良好的投资效益。'
                        }),
                        this.createText({
                            text: '    3)定期检测评定',
                            font: { size: 26 },
                            heading: HeadingLevel.HEADING_3,
                            spacing: { before: 100, after: 100 }
                        }),
                        this.createText({
                            text: '    运营单位每年组织隧道机电设施的定期检测,定期检测应选择第三方具备资质单位,提供定检报告。定期检查项目内容包括:供配电设施、照明设施、通风设施、消防设施、监控与通信设施。'
                        }),
                        this.createText({
                            text: '    4)分项技术状况评定',
                            font: { size: 26 },
                            heading: HeadingLevel.HEADING_3,
                            spacing: { before: 100, after: 100 }
                        }),

                        this.createText({
                            text: '    隧道机电设施分项技术状况评定由最近一年隧道定检报告评分、机电设备维修频次和机电设备使用年限三部分组成。'
                        }),
                        this.createText({
                            text: '    通过查阅机电养护单位的隧道机电设施设备养护资料,将分项工程中自使用以来最大年度维修次数记为设备维修次数。维修频次得分应按下式(1)计算,Stuf为设备维修频次得分:'
                        }),
                        this.createImg({
                            baseImg: base64Img2,
                            width: 279,
                            height: 62,
                            spacing: { after: 100, befor: 100 },
                            alignment: 'center'
                        }),
                        ...this.createTextFor([
                            {
                                text: '    (1)式中:Fmtuax---隧道机电设施维修次数,当Fmtuax为0时,Sf为100。'
                            },
                            {
                                text: '    隧道机电设施分项工程中使用年限最长的设备,其使用年限记为该分项工程的使用年限,该分项工程的使用年限得分应按式(2)计算,Stud为分项工程使用年限得分:'
                            }
                        ]),
                        this.createImg({
                            baseImg: base64Img3,
                            width: 309,
                            height: 69,
                            spacing: { after: 100, befor: 100 },
                            alignment: 'center'
                        }),
                        ...this.createTextFor([
                            {
                                text: '    (2)式中:Ytup---建议使用年限;'
                            },
                            {
                                text: '        Ytuu---已经使用年限。'
                            },
                            {
                                text: '        当Ytup小于Ytuu时,Stud为0。'
                            },
                            {
                                text: '    隧道机电设施分项工程技术状况评定宜按照式(3)计算,'
                            }
                        ]),
                        this.createImg({
                            baseImg: base64Img4,
                            width: 353,
                            height: 36,
                            spacing: { after: 100, befor: 100 },
                            alignment: 'center'
                        }),
                        ...this.createTextFor([
                            {
                                text: '    (3)式中:Stu---隧道机电设施分项工程术状况等级得分;'
                            },
                            {
                                text: '        wtur---隧道机电设施分项工程技术检测权重系数;'
                            },
                            {
                                text: '        Stur---最近一年隧道定检报告中该分项工程技术状况得分;'
                            },
                            {
                                text: '        wtuf---隧道机电设施分项工程维修频率权重系数;'
                            }, {
                                text: '        wtud---隧道机电设施分项工程使用年限权重系数。'
                            }, {
                                text: '权重系数建议取值见表2-1。'

                            }, {
                                text: '表2-1权重系数建议取值表',
                                alignment: 'center'
                            }
                        ]),
                        this.createTableFor(docxList.table2Data.widthList, {
                            left: 100,
                            top: 20,
                            bottom: 20
                        }, { text: docxList.table2Data.list, alignment: 'center' }),
                        ...this.createTextFor([
                            {
                                text: '    隧道机电设施分项工程技术状况按表2-2分为1类、2类、3类、4类。',
                                spacing: { before: 150, line: 340 }
                            },
                            {
                                text: '表2-2分项工程技术状况等级界限表',
                                alignment: 'center'
                            }
                        ]),
                        this.createTableFor(docxList.table3Data.widthList, {
                            left: 100,
                            top: 20,
                            bottom: 20
                        }, { text: docxList.table3Data.list, alignment: 'center' }),
                        ...this.createTextFor([
                            {
                                text: '    不同等级的分项工程应按表2-3中的养护建议采取对应的养护措施。',
                                spacing: { before: 150, line: 340 }
                            },
                            {
                                text: '表2-3分项工程养护建议',
                                alignment: 'center'
                            }
                        ]),
                        this.createTableFor(docxList.table4Data.widthList, {
                            left: 100,
                            top: 20,
                            bottom: 20
                        }, { text: docxList.table4Data.list, alignment: 'left' }),
                        this.createText({
                            text: '三、隧道机电养护决策分析成果及建议',
                            font: { size: 32 },
                            heading: HeadingLevel.HEADING_1,
                            spacing: { before: 10, after: 150 }
                        }),

                        new Paragraph({ // 创建段落
                            children: [
                                new TextRun({ // 创建文本对象
                                    text: '    基于以上决策评分方法,可以计算出国家级高速公路' + (parseInt(docxList.year) - 1) + '年度隧道机电设施技术状况评定表。', // 文本
                                    bold: false,
                                    size: 24
                                }),
                                new TextRun({ // 创建文本对象
                                    text: '根据表2-5分部设施状况等级划分,五大分部设施状况评级在3级及以下的隧道,需加强日常预防性养护,并对损坏设备及时修复,不再纳入本次决策建议计划。五大分部设施中,存在状况评级4级的隧道,纳入本次决策建议计划。', // 文本
                                    bold: true,
                                    size: 24
                                }),
                                new TextRun({ // 创建文本对象
                                    text: '山东省国家级高速公路养护决策分析包括:养护需求分析、养护建议计划二个方面。', // 文本
                                    bold: false,
                                    size: 24
                                })
                            ],
                            heading: HeadingLevel.TITLE,
                            spacing: { before: 0, after: 0, line: 340 }, // 距其他元素距离
                            alignment: 'left'
                        }),

                        ...this.createTextFor([
                            {
                                text: '3.1养护需求分析',
                                font: { size: 28 },
                                heading: HeadingLevel.HEADING_2,
                                spacing: { before: 0, after: 100 }
                            },
                            {
                                text: '    根据系统科学决策系统计算的' + docxList.year + '各隧道机电设施技术状况评定结果,采用高标准对山东省国家级高速公路隧道进行养护需求分析,得到' + docxList.year + '专项修复养护需求的隧道为' + docxList.tunnelTotalNum + '座。各隧道机电涉及专项修复养护需求的分项设施见附录1.'
                            },
                            {
                                text: '3.2工程量与估算分析',
                                font: { size: 28 },
                                heading: HeadingLevel.HEADING_2,
                                spacing: { before: 0, after: 100 }
                            },
                            {
                                text: '    基于3.1中对养护需求的分析,结合系统中的机电维护数据,对山东省国家级高速公路隧道进行专项工程工程量估计和养护费用估算分析,分析结果详见表3-1。 '
                            },
                            {
                                text: '表3-1隧道机电设施专项工程工程量与养护费用估算分析表',
                                alignment: 'center'
                            }
                        ]),
                        this.createTableMergeHandle(docxList.table5Data),
                        ...this.createTextFor([
                            {
                                text: '3.3隧道养护建议计划',
                                font: { size: 28 },
                                heading: HeadingLevel.HEADING_2,
                                spacing: { before: 0, after: 100 }
                            },
                            {
                                text: '    基于以上数据,综合考虑隧道机电技术状况、技术等级和交通量等因素,结合分析优选,' + docxList.year + '隧道机电养护建议计划共'+ docxList.needMaintain+'座,总计养护费用为'+ docxList.totalMaintainFee+'万元。详细估算参见表3-2。'
                            },
                            {
                                text: '表3-2各隧道决策推荐计划汇总',
                                alignment: 'center'
                            }
                        ]),
                        this.createTableFor(docxList.table6Data.widthList, {
                            left: 100,
                            top: 20,
                            bottom: 20
                        }, { text: docxList.table6Data.list, alignment: 'center' }),

                        this.createText({
                            text: '附录1:' + docxList.year + '隧道机电专项修复养护分项设施汇总表',
                            font: { size: 32 },
                            heading: HeadingLevel.HEADING_1,
                            spacing: { before: 100, after: 100 },
                            alignment: 'center',
                            pageBreakBefore: true

                        }),
                        this.createTable(docxList.table7DataHeader.columnWidths, {
                            top: 20,
                            bottom: 20
                        }, { text: docxList.table7DataHeader.list, alignment: 'center', font: { bold: true } }),

                        this.createTableMergeHandle(docxList.table7Data),

                        // ---- 分页符 -----
                        // this.createPageBreakBefore(),
                        // this.createText({
                        //     text: '    '
                        // })
                        // // 合并单元格测试
                        // this.createTableMerge(),
                    ]
                }
            ]
        })
        return doc
    }

    //--------------------------------上述代码为测试示例代码--------------------------------------

    // 公共创建段落区域
    createText({ text, font, spacing, alignment, indent, heading, pageBreakBefore }) {
        return new Paragraph({ // 创建段落
            children: [
                new TextRun({ // 创建文本对象
                    text, // 文本
                    font: font?.name || '宋体', // 字体 (例如:"宋体")
                    size: font?.size || 24, // 字号 (例如:14)-- 注意:以size:18为小五为例子 -- 21五号字 -- 具体使用自己调整
                    color: font?.color || '000000', // 颜色 (例如:"000000")
                    underline: font?.underline, // 下划线(例如:"single")
                    bold: font?.bold || false, // 是否加粗(例如:true)
                    italic: font?.italic || false, // 是否斜体(例如:true)
                    strike: font?.strike || false, // 删除线(例如:true)
                    subscript: font?.subscript || false, // 下标(例如:true)
                    superscript: font?.superscript || false // 上标(例如:true)
                })
            ],
            heading: heading || HeadingLevel.TITLE,
            spacing: spacing || { before: 0, after: 0, line: 320 }, // 距其他元素距离
            alignment: alignment || 'left', // 对齐方式 左对齐 AlignmentType.LEFFT  居中对齐 'center'  右对齐 AlignmentType.RIGHT
            indent: indent, // 缩进 例如,设置indent: 720可以实现一个1英寸的左缩进。 -- { left: 720 } (左缩进)  right(右缩进)、firstLine(首行缩进)
            pageBreakBefore // 如果设置为true,则在该段落之前会强制插入一个新页。 -- 如果当前段落为首项则不会生效
        })
    }

    // 传数组,循环创建段落
    createTextFor(list) {
        let arr = []
        list.forEach((item) => {
            arr.push(this.createText(item))
        })
        return [...arr]
    }

    // 公共创建图片
    createImg({ baseImg, width, height, text, spacing, alignment }) {
        return new Paragraph({ // 创建段落
            children: [
                new ImageRun({
                    data: baseImg,
                    transformation: {
                        width: width || 100,
                        height: height || 100
                    },
                    alignment: 'center'
                    // floating: {
                    //   zIndex: 5,
                    //   // 水平定位
                    //   horizontalPosition: {
                    //     relative: HorizontalPositionRelativeFrom.MARGIN,
                    //     align: HorizontalPositionAlign.CENTER
                    //   },
                    //   // // 垂直定位
                    //   verticalPosition: {
                    //     relative: HorizontalPositionRelativeFrom.MARGIN,
                    //     align: HorizontalPositionAlign.CENTER
                    //   }
                    // }
                })
            ],
            spacing,
            alignment: alignment || 'center'
        })
    }

    // 分页 - 两种方法,可根据实际情况使用
    createPageBreakBefore() {
        // 移动到新页面(插入分页符):
        return new Paragraph({
            children: [new PageBreak()]
        })
        // // 将确保段落将在新页面上开始(如果它还没有在新页面上)
        // return new Paragraph({
        //   pageBreakBefore: true,
        // })
    }

    // 公共调用创建表格区域 -- 单行表格
    // { new Table配置项 } { new TableRow配置项 } { new Table配置项 } { createText方法传入配置项 } -- 可能写的比较繁琐 -- 实际开发可根据具体需求 -- 因为大部门值其实都是固定的
    createTable(
        columnWidths,
        margins,
        { text, font, spacing, alignment, indent, pageBreakBefore }) {
        // 创建表格项
        return new Table({
            columnWidths: columnWidths || [1800, 1800, 1800, 1800, 1800], // 每个单元格宽度
            layout: TableLayoutType.FIXED,
            rows: text.map(x => {
                return new TableRow({
                    children: x.map((v, childIndex) => {
                        return new TableCell({
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: margins || { top: 20, bottom: 20 }, // 设置边距 -- 用来撑开单元格
                            children: [
                                this.createText({ text: v, alignment: alignment, font: font })
                            ]
                        })
                    })
                })
            })
        })
    }

    // 公共调用创建表格区域 -- 循环生成多行表格 -- 不再写各个属性配置项 -- 有需要看 createTable 公共方法  有具体描述
    createTableFor(
        columnWidths,
        margins,
        { text, font, spacing, alignment, indent, pageBreakBefore }) {
        // 创建表格项
        return new Table({
            columnWidths: columnWidths || [1800, 1800, 1800, 1800, 1800], // 每个单元格宽度
            layout: TableLayoutType.FIXED,
            rows: text.map((x, index) => {
                return new TableRow({ // 列
                    children: x.value.map((v, childIndex) => {
                        // 如果不为数组,将其转换为数组
                        if (typeof (v) !== 'object') v = [v]
                        // // 匹配\n换行符号,将其组成['','']此格式
                        // v.forEach((item, index) => {
                        //     v = item.split('\n')
                        // })
                        return new TableCell({ // 行
                            width: {
                                size: columnWidths ? columnWidths[childIndex] : 1000,
                                type: WidthType.DXA
                            },

                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: margins || { top: 100, bottom: 100 }, // 设置边距 -- 用来撑开单元格
                            children: v.map(ite => { // 针对\n 换行符,将其每一段输出成一个段落 -- 以实现换行效果
                                return this.createText({ text: ite, font, spacing, alignment, indent, pageBreakBefore })
                            })
                        })
                    })
                })
            })
        })
    }

    // 生成合并单元格的表格
    createTableMergeHandle({ hasHeader, columnWidths, list }) {
        return new Table({ // 固定信息示例
            columnWidths: columnWidths, // 每个单元格宽度
            layout: TableLayoutType.FIXED,
            rows: list.map((item, index) => {
                let bold = hasHeader && index == 0 ? true : false
                return new TableRow({
                    children: item.row.map((t, childIndex) => {
                        return new TableCell({
                            children: [this.createText({ text: t.text, alignment: 'center', font: { bold: bold } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 50, bottom: 50 },
                            rowSpan: t.rowSpan, // 设置跨 n 行 -- 注意:此处用的是跨来描述 --
                            columnSpan: 1 // 设置跨 2 列// 设置边距 -- 用来撑
                        })
                    })
                })
            })
        })
    }

    // 合并单元格测试
    createTableMerge() {
        // 创建表格项
        return new Table({ // 固定信息示例
            columnWidths: [1125, 1125, 1125, 2250, 1125, 1125, 1125], // 每个单元格宽度
            layout: TableLayoutType.FIXED,
            rows: [
                new TableRow({
                    children: [
                        new TableCell({
                            children: [this.createText({ text: '序号', font: { bold: true } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 100, bottom: 100 } // 设置边距 -- 用来撑
                        }),
                        new TableCell({
                            children: [this.createText({ text: '隧道名称', font: { bold: true } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 100, bottom: 100 } // 设置边距 -- 用来撑
                        }),
                        new TableCell({
                            children: [this.createText({ text: '分部设施', font: { bold: true } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 100, bottom: 100 } // 设置边距 -- 用来撑
                        }),
                        new TableCell({
                            children: [this.createText({ text: '分项设施', font: { bold: true } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 100, bottom: 100 } // 设置边距 -- 用来撑
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单位', font: { bold: true } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 100, bottom: 100 } // 设置边距 -- 用来撑
                        }),
                        new TableCell({
                            children: [this.createText({ text: '工程量', font: { bold: true } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 100, bottom: 100 } // 设置边距 -- 用来撑
                        }),
                        new TableCell({
                            children: [this.createText({ text: '估算(万元)', font: { bold: true } })],
                            verticalAlign: 'center', // 设置字在单元格对齐方式 垂直居中
                            margins: { top: 100, bottom: 100 } // 设置边距 -- 用来撑
                        })
                    ]
                }),

                new TableRow({
                    children: [
                        new TableCell({
                            children: [this.createText({ text: '1' })],
                            rowSpan: 6, // 设置跨 2 行 -- 注意:此处用的是跨来描述 -- 代表这个单元格会占据3行 -- 前提是存在3个new TableRow
                            columnSpan: 1, // 设置跨 2 列
                            verticalAlign: 'center' // 设置字在单元格对齐方式 垂直居中
                        }),
                        new TableCell({
                            children: [this.createText({ text: '港沟隧道' })],
                            rowSpan: 6, // 设置跨 2 行 -- 注意:此处用的是跨来描述 -- 代表这个单元格会占据3行 -- 前提是存在3个new TableRow
                            columnSpan: 1, // 设置跨 2 列
                            verticalAlign: 'center' // 设置字在单元格对齐方式 垂直居中
                        }),
                        new TableCell({
                            children: [this.createText({ text: '供配电设施' })],
                            rowSpan: 2, // 设置跨 2 行 -- 注意:此处用的是跨来描述 -- 代表这个单元格会占据3行 -- 前提是存在3个new TableRow
                            columnSpan: 1, // 设置跨 2 列
                            verticalAlign: 'center' // 设置字在单元格对齐方式 垂直居中
                        }),
                        new TableCell({
                            children: [this.createText({ text: '抵押开关柜' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '套' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '8' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '39.8' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        })
                    ]
                }),
                new TableRow({
                    children: [
                        new TableCell({
                            children: [this.createText({ text: '自卑发电设备' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        })

                    ]
                }),
                new TableRow({
                    children: [
                        new TableCell({
                            children: [this.createText({ text: '照明设施' })],
                            rowSpan: 2, //
                            columnSpan: 1, // 设置跨 2 列
                            verticalAlign: 'center' // 设置字在单元格对齐方式 垂直居中
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        })
                    ]
                }),
                new TableRow({
                    children: [
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        })

                    ]
                }),
                new TableRow({
                    children: [
                        new TableCell({
                            children: [this.createText({ text: '监控与通信设备' })],
                            rowSpan: 2, //
                            columnSpan: 1, // 设置跨 2 列
                            verticalAlign: 'center' // 设置字在单元格对齐方式 垂直居中
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        })
                    ]
                }),
                new TableRow({
                    children: [
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        }),
                        new TableCell({
                            children: [this.createText({ text: '单元格 2' })],
                            verticalAlign: 'center',
                            margins: { top: 100, bottom: 100 }
                        })

                    ]
                })
            ]
        })
    }

    // 示例模板
    // 公共调用创建表格区域 -- 单行表格
    // { new Table配置项 } { new TableRow配置项 } { new Table配置项 } { createText方法传入配置项 } -- 可能写的比较繁琐 -- 实际开发可根据具体需求 -- 因为大部门值其实都是固定的
    createTableTemplate(
        { TableColumnWidths, TableHeight, TableBorders },
        { TableRowCantSplit, TableRowTableHeader },
        { TableCellWidth, TableCellMargins, TableCellBorders, TableCellVerticalAlign, TableCellShading },
        { text, font, spacing, alignment, indent, pageBreakBefore }) {
        // 创建表格项
        return new Table({
            columnWidths: TableColumnWidths || [750, 1000, 3750, 1000, 2500], // 设置表格中各列的宽度 以9000磅(点)为基准  例如:[750, 1000, 3750, 1000, 2500]
            borders: { // 定义表格的边框样式
                top: TableBorders?.top || {
                    // style: BorderStyle.DOTTED, // 设置顶部边框样式 -- SINGLE:单实线边框样 -- DASHED:虚线边框样式 -- DOTTED:点线边框样式 -- DOUBLE:双实线边框样式 -- NONE:无边框样式
                    color: '000000' // 设置边框颜色为黑色
                    // size: 1, // 设置边框大小为1磅
                }
                // bottom  设置表格底部边框的样式,用法与top类似。
                // left:设置表格左侧边框的样式,用法与top类似。
                // right:设置表格右侧边框的样式,用法与top类似。
                // insideHorizontal:设置表格内部水平边框的样式,用法与top类似。
                // insideVertical:设置表格内部垂直边框的样式,用法与top类似。
            },
            rows: [ // 设置表格行数和行对象
                new TableRow({ // 创建表格行
                    cantSplit: TableRowCantSplit || true, // 设置是否禁止表格行跨页分割 true(禁止分割)或false(允许分割)
                    tableHeader: TableRowTableHeader || false, // 设置是否将表格行视为表格的标题行,默认值为false。如果设置为true,则表格行将被视为表格的标题行,表格标题行通常具有不同的样式。
                    children: [
                        // 创建表格列
                        new TableCell({
                            width: TableCellWidth || {
                                size: 750, // 设置单元格的宽度 总值一般按9000算
                                type: WidthType.DXA // 使用DXA单位来定义表格单元格宽度。
                            },

                            margins: TableCellMargins || { // 设置单元格的边距
                                top: 1000,
                                right: 0,
                                bottom: 1000,
                                left: 0
                            },

                            shading: TableCellShading || {
                                // fill: "FF0000", val: ShadingType.REVERSE_DIAGONAL_STRIPE   // 设置底纹颜色为红色 -- 使用反对角线条纹样式
                                // ShadingType.CLEAR:清除底纹,即无底纹。
                                // ShadingType.SOLID:实心底纹。
                                // ShadingType.HORIZONTAL_STRIPE:水平条纹底纹。
                                // ShadingType.VERTICAL_STRIPE:垂直条纹底纹。
                                // ShadingType.REVERSE_DIAGONAL_STRIPE:反对角线条纹底纹。
                                // ShadingType.DIAGONAL_STRIPE:对角线条纹底纹。
                                // ShadingType.DIAGONAL_CROSShatch:对角交叉线底纹。
                                // ShadingType.THICK_HORIzONTAL:粗水平线底纹。
                                // ShadingType.THICK_VERTICAL:粗垂直线底纹。
                            },

                            border: TableCellBorders || {
                                // top: { color: "000000", space: 1, value: BorderStyle.DOT_DOT_DASH }, // 设置顶部边框为点点虚线样式,底部边框为虚线样式
                                // space 配置项:
                                // 0:边框与内容紧密相邻,无额外间距。
                                // 1:边框与内容之间有一个小间距。
                                // 2:边框与内容之间有一个中等间距。
                                // 3:边框与内容之间有一个大间距。

                                // value 配置项:
                                // BorderStyle.NONE:无边框。
                                // BorderStyle.SINGLE:单线边框。
                                // BorderStyle.THICK:粗线边框。
                                // BorderStyle.DOUBLE:双线边框。
                                // BorderStyle.DOT:点线边框。
                                // BorderStyle.DASH:破折号线边框。
                                // BorderStyle.DASH_DOT:破折号和点线边框。
                                // BorderStyle.DASH_DOT_DOT:破折号和两个点线边框。
                                // BorderStyle.SINGLE_WAVE:单波浪线边框。
                                // BorderStyle.DOUBLE_WAVE:双波浪线边框。
                                // BorderStyle.DOT_DOT_DASH:两点和破折号边框。
                            },

                            verticalAlign: TableCellVerticalAlign || 'center', // 设置字在单元格对齐方式 垂直居中
                            rowSpan: 3, // 设置跨 2 行 -- 注意:此处用的是跨来描述 -- 代表这个单元格会占据3行 -- 前提是存在3个new TableRow
                            columnSpan: 2, // 设置跨 2 列
                            children: [
                                new Paragraph({ // 创建段落
                                    children: [
                                        new TextRun({ // 创建文本对象
                                            text, // 文本
                                            name: font?.name || '宋体', // 字体 (例如:"宋体")
                                            size: font?.size || 18, // 字号 (例如:14)-- 注意:以size:18为小五为例子 -- 21五号字 -- 具体使用自己调整
                                            color: font?.color || '000000', // 颜色 (例如:"000000")
                                            underline: font?.underline, // 下划线(例如:"single")
                                            // true:显示未格式化的下划线。
                                            // false:不显示下划线。
                                            // 'dash':显示虚线下划线。
                                            // 'dashDotDotHeavy':显示双点虚线下划线。
                                            // 'dashLong':显示长虚线下划线。
                                            // 'dashLongHeavy':显示粗长虚线下划线。
                                            // 'dotDash':显示点虚线下划线。
                                            // 'dotted':显示点下划线。
                                            // 'dottedHeavy':显示粗点下划线。
                                            // 'double':显示双下划线。
                                            // 'single':显示单下划线。
                                            // 'thick':显示粗下划线。
                                            // 'wave':显示波浪线下划线。
                                            // 'wavyDouble':显示双波浪线下划线。
                                            // 'wavyHeavy':显示粗波浪线下划线。
                                            // 'words':只在单词下划线
                                            bold: font?.bold || false, // 是否加粗(例如:true)
                                            italic: font?.italic || false, // 是否斜体(例如:true)
                                            strike: font?.strike || false, // 删除线(例如:true)
                                            subscript: font?.subscript || false, // 下标(例如:true)
                                            superscript: font?.superscript || false // 上标(例如:true)
                                        })
                                    ],
                                    spacing: spacing || { before: 0 }, // 距其他元素距离
                                    alignment, // 对齐方式 左对齐 AlignmentType.LEFFT  居中对齐 'center'  右对齐 AlignmentType.RIGHT
                                    indent, // 缩进 例如,设置indent: 720可以实现一个1英寸的左缩进。 -- { left: 720 } (左缩进)  right(右缩进)、firstLine(首行缩进)
                                    pageBreakBefore // 如果设置为true,则在该段落之前会强制插入一个新页。 -- 如果当前段落为首项则不会生效
                                })
                            ]
                        })
                    ]
                })
            ]
        })
    }

}

index.js 位置:utils/index.js

javascript 复制代码
// 下载文件流  
export const downloadFile = (res, val) => {
  const blob = new Blob([res], {
    type: "application/vnd.openxmlformats-officedocument.wordprocessingml.document" // for .docx files
  }) // for .xlsx files

  // 通过URL.createObjectURL生成文件路径
  const url = window.URL.createObjectURL(blob)

  // 创建a标签
  const ele = document.createElement("a")
  ele.style.display = "none"
  ele.download = val ? val : '模板'
  // 设置href属性为文件路径,download属性可以设置文件名称
  ele.href = url
  // 将a标签添加到页面并模拟点击
  document.querySelectorAll("body")[0].appendChild(ele)
  ele.click()

  // 移除a标签
  ele.remove()
}

base64Img.js (base64格式的图片) 位置:utils/base64Img.js

javascript 复制代码
export const base64Img1="
相关推荐
大道归简22 分钟前
案例:自动化获取Web页面小说(没钱修什么仙)——selenium
前端·selenium·自动化
跑马的程序员6 小时前
word模板填充导出-(支持word导出、pdf导出)
pdf·word
Deepsleep.6 小时前
东田数码科技前端面经
前端·科技·面试
涵信7 小时前
第十八节:开放性问题-Vue生态未来趋势
前端·vue.js·devops
牧杉-惊蛰8 小时前
css 数字从0开始增加的动画效果
前端·javascript·css
孤灯淡茶8 小时前
Fiori学习专题十五:Nested Views
前端·javascript·学习
green_pine_8 小时前
CSS学习笔记14——移动端相关知识(rem,媒体查询,less)
前端·css·笔记·学习·less
Monly218 小时前
Vue:el-table-tree懒加载数据
前端·javascript·vue.js
进取星辰8 小时前
16、路由守卫:设置魔法结界——React 19 React Router
前端·javascript·react.js
清羽_ls9 小时前
cURL 入门:10 分钟学会用命令行发 HTTP 请求
前端·curl·命令行工具