html-docx-js-typescript——将html生成docx文档

html-docx-js-typescript源码:GitHub - caiyexiang/html-docx-js-typescript: Convert HTML documents to docx format.

html-docx-js地址:html-docx-js - npm

*简单使用:

获取需要转为word文档的html节点,借助file-saver提供的saveAs方法和html-docx-js提供的asBlob方法转换我们设置好的html即可。

简单使用:
import htmlDocx from "html-docx-js/dist/html-docx";
import { saveAs } from "file-saver";
import $ from "jquery";function exportWord(dom, fileName) {setTimeout(() => {let htmlStr = `<!DOCTYPE html><html lang="en"><body style="font-family:方正仿宋_GBK;mso-ascii-font-family:'Times New Roman'">${dom.html()}</body></html>`;saveAs( htmlDocx.asBlob(htmlStr, { orientation: "landscape" }), fileName );}, 200);
}

*demo示例:

 

包含图片( echarts可直接通过自带的方法.getConnectedDataURL({ type: "png" })获取base64)

// img图片转换base64
// 结构<div><h1>html转化word</h1><p>Enter/paste your document here:</p><textarea id="content" cols="60" rows="10"><p>We all live in a yellow submarine, yellow submarine, yellow submarine, yellow submarine</p><p>Images can also be exported if you source them as base64 DATA URI.</p><img src="cat.jpg" /><img src="http://docs.asprain.cn/javatutorial/images/oracle-java-logo.png" /></textarea><div class="page-orientation"><span>Page orientation:</span><label><input type="radio" name="orientation" value="portrait" checked>Portrait</label><label><input type="radio" name="orientation" value="landscape">Landscape</label></div><button id="convert">Convert</button><div id="download-area"></div></div>
// script
<script src="./FileSave.js"></script>
<script src="./html-docx.js"></script>
// 逻辑
document.getElementById('convert').addEventListener('click', function(e) {e.preventDefault();const content1 = document.getElementById('output').innerHTML;const content = document.getElementById('content').value;embedImage(content).then((content) => {var orientation = document.querySelector('.page-orientation input:checked').value;var blob = htmlDocx.asBlob(content, {orientation: orientation});saveAs(blob, 'test.docx');var link = document.createElement('a');link.href = URL.createObjectURL(blob);link.download = 'document.docx';link.textContent='Click here if your download has not started automatically';var downloadArea = document.getElementById('download-area');downloadArea.innerHTML = '';downloadArea.appendChild(link);});});/*** @desc 将图片嵌入HTML中* @param {html} String* @return Promise(html)*/function embedImage(html){if(typeof(html) !== 'string') return;let doc = new DOMParser().parseFromString(html, 'text/html');debugger;let images = doc.images;//if(images.length==0)return '<!doctype html>'+doc.documentElement.outerHTML;return new Promise((resolve,reject)=>{function _iterate(i){if(i==images.length){resolve('<!doctype html>'+doc.documentElement.outerHTML);return;// 终于}let img=images[i];let url=img.src;// 正在嵌入第i张图片getBase64(url,function(base64){if(base64==null){img.remove();_iterate(i);}else {img.src=base64;_iterate(++i);}})}_iterate(0);})}/*** @desc 从URL取得base64* @param {url} String 网址* @param {callback} Function 如果能打开图片,参数为打开图片的blob,如果不能打开图片,参数为null* @return void*/function getBase64(url,callback) {const xhr = new XMLHttpRequest();xhr.responseType='blob'xhr.onload = () => {const blob=xhr.response;var reader = new FileReader();reader.onload = function (e) {callback(reader.result);}reader.readAsDataURL(blob);};xhr.onerror = (err) => {callback(null)};xhr.open('GET', url, true);xhr.send(null);}
设置样式

找到需要操作的dom元素,dom添加行内样式即可,注意:添加行内样式时,需要注意代码执行顺序,避免有些行内样式被覆盖。

项目中遇到问题:

1.util问题

 

参考:Module not found: Error: Can‘t resolve ‘path‘_can't resolve 'path-CSDN博客

 

2.表格样式问题

参考:JS word下载(含两种方式:html转word、模板转word) - 简书

3.html-docx-js的with函数问题

修改源码:

 

参考:JS word下载(含两种方式:html转word、模板转word) - 简书

插件推荐 | html文本转docx文档 - 简书

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/754418.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NFS性能优化参考 —— 筑梦之路

CentOS 7 NFS服务优化的配置参考—— 筑梦之路_nfs 读取优化-CSDN博客 核心原则是减少客户端与服务端的交互次数&#xff0c;因此我们在访问文件的时候应该尽量保持文件的打开状态&#xff0c;避免重复打开关闭文件&#xff0c;这样NFS全路径的逐级检查。这种方法对NFSv4以后的…

项目域名协议https,访问接口链接协议http

问题&#xff1a;前端页面调用后端接口加载不出来 原因&#xff1a; 控制台警告&#xff1a; Mixed Content: The page at https://* was loaded over HTTPS, but requested an insecure XMLHttpRequest endpoint http://*. This request has been blocked; the content must b…

判断闰年(C语言)

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>int main() {//初始化变量值&#xff1b;int year 2000;//执行循环判断&#xff1b;while (year < 2010){//执行流程&#xff1b;//判断能否整除4&#xff1…

Chrome历史版本下载地址:Google Chrome Older Versions Download (Windows, Linux Mac)

最近升级到最新版本Chrome后发现页面居然显示错乱,是在无语, 打算退回原来的版本, 又发现官方只提供最新的版本下载, 为了解决这个问题所有收集了Chrome历史版本的下载地址分享给大家. Google Chrome Windows version 32-bit VersionSizeDate104.0.5112.10279.68 MB2022-05-30…

Vue3学习日记 Day4 —— pnpm,Eslint

注&#xff1a;此课程需要有Git的基础才能学习 一、pnpm包管理工具 1、使用原因 1.1、速度快&#xff0c;远胜过yarn和npm 1.2、节省磁盘空间 2、使用方式 2.1、安装方式 npm install -g pnpm 2.2、创建项目 pnpm create vue 二、Eslint配置代码风格 1、环境同步 1、禁用Pret…

华为配置WAPI-PSK安全策略实验

配置WAPI-PSK安全策略示例 组网图形 图1 配置WAPI-PSK安全策略组网图 配置流程组网需求配置思路配置注意事项操作步骤配置文件 配置流程 WLAN不同的特性和功能需要在不同类型的模板下进行配置和维护&#xff0c;这些模板统称为WLAN模板&#xff0c;如域管理模板、射频模板、VAP…

基于单片机的机电控制实训平台设计

摘 要:自主研制一种基于单片机的机电控制实训平台。该平台由单片机主控单元及多个独立的功能模块单元组成,主控单元支持51或AVR系列单片机,各个功能模块独立设计,并可利用杜邦线进行组合连接。平台可实现单片机基本控制功能及典型机电控制功能,包括直流电机和微型步…

目标检测常见数据集格式(YOLO、VOC、COCO)

目录 1.YOLO格式数据 1.1数据格式 1.2YOLO格式数据示例 1.3YOLO格式可视化 2.COCO数据格式 2.1数据格式 2.2COCO格式数据示例 2.3COCO格式可视化 3.VOC数据格式 3.1数据格式 3.2VOC格式数据示例 3.3COCO格式可视化 &#x1f353;&#x1f353;1.YOLO格式数据 &…

C#LiteDB基本使用

C#LiteDB基本使用 LiteDB基本使用1.创建实体类2.连接数据库以及一些CRUD LiteDB基本使用 1.创建实体类 创建一个实体类 {public int Id { get; set; }public int Age { get; set; }public string Name { get; set; } string.Empty;public string[] Phone { get; set; }publ…

Jenkins使用pipeline流水线部署项目

新建流水线任务 前面的项目整个部署日志都在一个控制台页面&#xff0c;出现了错误不能快速定位不方便查阅 Jenkins提供了流水线方式的任务 这里我新建一个叫“pipeline-mytest”的流水线任务 在流水线出右侧有内置的样式&#xff0c;这里我选择了helloworld的样式。 构建一…

Apache Doris 2.0.6 版本正式发布

亲爱的社区小伙伴们&#xff0c;Apache Doris 2.0.6 版本已于 2024 年 3 月 12 日正式与大家见面&#xff0c;该版本在物化视图、统计信息收集、JDBC Catalog 等方面进行了更新优化&#xff0c;并提交了 114 个改进项以及问题修复&#xff0c;欢迎大家下载体验。 官网下载&…

25考研|北大软微会「爆炸」吗?

软微不是已经爆炸了吗&#xff1f; 大家去看看他的录取平均分就知道了&#xff0c;没有实力千万别碰&#xff0c;现在考软微已经不存在捡漏之说。 110408的复试线已经划到了465分&#xff0c;这个人真的不低了&#xff0c;因为有数学一和408两个比较难的专业课&#xff0c;复…

网络编程 - 套接字

1、预备知识 1.1、理解源IP地址和目的IP地址 在IP数据包头部中, 有两个IP地址, 分别叫做源IP地址, 和目的IP地址&#xff1b; 思考: 我们光有IP地址就可以完成通信了嘛? 想象一下发qq消息的例子, 有了IP地址能够把消息发送到对方的机器上, 但是还需要有一个其他的标识来区分…

完成系统支持Github三方登录

文章目录 1、需求2、在对接系统中完成客户端注册3、创建客户端应用4、CommonOAuth2Provider SpringSecurity OAuth2.0文档&#xff1a; https://docs.spring.io/spring-security/reference/servlet/oauth2/index.html 1、需求 对接Github&#xff0c;在自己系统实现支持Githu…

【C#语言入门】22. 接口、依赖反转、单元测试

【C#语言入门】22. 接口、依赖反转、单元测试 一、接口与单元测试 接口的产生&#xff1a;自底向上&#xff08;重构&#xff09;&#xff0c;自顶向下&#xff08;设计&#xff09;C#中接口的实现&#xff08;隐式&#xff0c;显式&#xff0c;多接口&#xff09;语言对面向…

【力扣hot100】49. 字母异位词分组

题目 给你一个字符串数组&#xff0c;请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 示例 1: 输入: strs [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”] 输出: [[“bat”],[“nat”,…

Visual Studio工程升级QT产生的问题及解决

文章目录 小结问题及解决QT的路径问题0xC0000139: Entry Point Not Found 参考 小结 最近将QT从版本5.3.2升级到了5.12.7&#xff0c;经及将VS2012工程升级到VS2015&#xff0c;碰到了一些问题&#xff0c;例如路径问题&#xff0c;程序无法启动的问题&#xff08;Entry Point…

k8s client-java创建pod常见问题

1.配置Kubernetes连接&#xff1a; 使用Kubernetes的配置文件&#xff08;通常位于~/.kube/config&#xff09;或直接使用API服务器地址、认证信息等来配置客户端。 配置通常有两种模式&#xff0c;安全和不安全的配置模式&#xff0c;对认证要求严格就选用安全模式&#xff…

实景剧本杀小程序儿童公园剧本杀小程序系统开发

开发实景剧本杀小程序儿童公园剧本杀系统需要考虑以下几个方面&#xff1a; 1. 游戏设计&#xff1a;设计适合儿童玩耍的剧本杀游戏&#xff0c;考虑场景、角色、任务、线索等因素&#xff0c;以适应儿童的理解力和参与度。 2. 技术实现&#xff1a;利用小程序技术框架进行系…

osgEarth学习笔记4-第一个OsgEarth QT程序

原文链接 使用QT Creator新建一个窗口项目。 编辑pro文件 QT core gui greaterThan(QT_MAJOR_VERSION, 4): QT widgets CONFIG c11 DEFINES QT_DEPRECATED_WARNINGS #DEFINES QT_DISABLE_DEPRECATED_BEFORE0x060000 # disables all the APIs deprecated bef…