Vue-纯前端导出word文档,ts版

本文介绍了如何在Vue+TS项目中实现纯前端导出Word文档,包括安装docxtemplater、jszip-utils、jszip和file-saver等依赖,以及在shims-lib.d.ts和tsconfig.json中进行类型声明和配置。同时,提供了导出Word的方法和示例代码,以及遇到问题时的参考链接。

Vue-纯前端导出word文档,ts版

安装依赖

安装 docxtemplater
cnpm install docxtemplater pizzip --save

安装 jszip-utils
cnpm install jszip-utils --save

安装 jszip
cnpm install jszip --save

安装 FileSaver
cnpm install file-saver --save

ps:项目如果是vue+ts
1、需要在shims-lib.d.ts文件手动声明:declare module ‘jszip’; declare module ‘jszip-utils’;
2、需要在tsconfig.json文件中的"compilerOptions"对象加"typeRoots": [“src/@types”, “./node_modules/@types”],还要修改"exclude": [“node_modules”, “src/@types/**/*”]

在需要的文件引入

import docxtemplater from 'docxtemplater';
import PizZip from 'pizzip';
import JSZipUtils from 'jszip-utils';
import { saveAs } from 'file-saver';

使用

方法

// 点击导出word 
  exportWord() {
    const tableData: any = this.tableData; //要导出word的数据
    // 读取并获得模板文件的二进制内容
    JSZipUtils.getBinaryContent(`/model.docx`, function (error: any, content: any) {
      // model.docx是模板。我们在导出的时候,会根据此模板来导出对应的数据
      // 抛出异常
      if (error) {
        throw error;
      }

      // 创建一个PizZip实例,内容为模板的内容
      let zip = new PizZip(content);
      // 创建并加载docxtemplater实例对象
      let doc = new docxtemplater().loadZip(zip);
      // 设置模板变量的值
      doc.setData({
        table: tableData,
      });

      try {
        // 用模板变量的值替换所有模板变量
        doc.render();
      } catch (error: any) {
        // 抛出异常
        let e = {
          message: error.message,
          name: error.name,
          stack: error.stack,
          properties: error.properties,
        };
        console.log(JSON.stringify({ error: e }));
        throw error;
      }

      // 生成一个代表docxtemplater对象的zip文件(不是一个真实的文件,而是在内存中的表示)
      let out = doc.getZip().generate({
        type: 'blob',
        mimeType: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
      });
      // 将目标文件对象保存为目标类型的文件,并命名
      saveAs(out, '视频参数.docx');
    });
  }

html

<el-button type="primary" @click="exportWord">导出word</el-button>

其他bug

可以参考:https://www.cnblogs.com/hejun26/p/13647927.html

### 实现 Vue 2 前端导出 Word 文档Vue 2 中实现前端导出 Word 文档的功能,可以通过引入 `file-saver` 和 `html-docx-js` 这两个库来完成。这些工具可以帮助开发者轻松地将 HTML 页面的内容转换为 Word 文件并提供下载。 #### 安装依赖 首先需要安装必要的依赖包: ```bash npm install file-saver html-docx-js ``` #### 示例代码 以下是完整的示例代码: ```javascript <template> <div> <button @click="exportWord">导出 Word</button> <div class="content-to-export"> <h1>这是要导出的标题</h1> <p>这是一个简单的段落。</p> <img src="https://via.placeholder.com/150" alt="示例图片"/> </div> </div> </template> <script> import { saveAs } from 'file-saver'; import * as ejs from 'ejs'; import * as htmlDocx from 'html-docx-js'; export default { methods: { exportWord() { const contentDiv = document.querySelector('.content-to-export'); const htmlContent = contentDiv.innerHTML; // 将HTML内容转为Word文档 const docxContent = htmlDocx.asBlob(htmlContent); // 设置文件名称 const currentDate = new Date().toLocaleDateString(); const fileName = `导出测试_${currentDate}.docx`; // 下载文件 saveAs(docxContent, fileName); } } }; </script> <style scoped> .content-to-export img { max-width: 100%; } </style> ``` 上述代码实现了以下功能: - 使用 `querySelector` 获取指定 DOM 节点中的内容[^3]。 - 利用 `html-docx-js` 库将 HTML 内容转化为 Word 文档格式的数据流[^2]。 - 结合 `file-saver` 提供的 API (`saveAs`) 来触发浏览器下载行为。 #### 关键点说明 1. **DOM 操作** 需要通过 JavaScript 的 DOM 方法提取目标区域内的 HTML 数据作为输入源。 2. **样式保留** 如果希望导出后的 Word 文档能够尽可能还原网页上的布局效果,则需要注意 CSS 样式的兼容性问题。部分复杂的样式可能无法完全被解析器识别和支持。 3. **性能优化** 对于较大规模或者包含大量多媒体资源(如高分辨率图像)的情况,建议先压缩素材再执行转化过程以减少最终生成文件体积过大带来的不便[^4]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值