Vue3——html-doc-js(html导出为word的js库)

一、下载

官方地址 html-doc-js - npm

javascript 复制代码
npm install  html-doc-js

二、使用方法

javascript 复制代码
// 使用页面中引入
import exportWord from 'html-doc-js'


// 配置项以及实现下载方法
const wrap = document.getElementById('test')const config = {
      document:document, //默认当前文档的document 导出内容是iframe内部时需要使用iframe的document(getElementById('#iframe').contentDocument),注意iframe同域
      addStyle:true, // 是否导出样式,默认为true,此操作会将所有样式转换成行内样式导出
      fileName:'测试', // 导出文件名(不需要后缀) 存在文件名则会直接下载 否则会仅在success中返回blob
      toImg: ["canvas", "mjx-math"], // 页面哪些部分需要转化成图片,例如echart图表之类
      success(blob,dom){} // 完成之后回调, blob及完整处理后dom
exportWord(wrap,config) 

三、解决公式转为图片后单行公式可能会出现图片和原本的字符串重复的问题

在 exportWord 方法执行时,将页面中mjx-assistive-mml 节点清除即可,如下图所示

javascript 复制代码
// 根据tagName清除编辑器不需要的内容
const clearMathTags = (targetInstance, tagName) => {
  let targetElement = document.querySelectorAll(tagName);
  if (targetElement && targetElement.length) {
    targetElement.forEach((element) => {
      element.remove();
    });
  }
};

四、解决下载后共识可能显示有误的问题

相关推荐
gjwjuejin7 分钟前
前端埋点第二弹:那些年我们踩过的坑,和填坑的正确姿势
javascript
A不落雨滴AI8 分钟前
DKERP客户端重构纪实:4天自研控件库的“短命”教训,以及为什么我坚定选择原生Qt
前端
我叫黑大帅10 分钟前
通过白名单解决 pnpm i 报错 Ignored build scripts
前端·javascript·面试
风止何安啊13 分钟前
用 APP 背单词太无聊?我用 Trae Solo 移动端写个小游戏来准备 6级
前端·人工智能·trae
Summer不秃16 分钟前
深入理解 Token 无感刷新:从并发雪崩到单例锁 + 请求队列的完整实现
前端·http
yingyima25 分钟前
Git 实战:你必须掌握的 7 个常用命令
前端
gjwjuejin26 分钟前
前端埋点不头秃:从打点代码到数据分析的完整实战
javascript
Schafferyy35 分钟前
【vue3】Form表单重置不生效
javascript·vue.js
次次皮36 分钟前
代理启动前端dist包
java·前端·vue
故事和你9138 分钟前
洛谷-【图论2-1】树4
开发语言·数据结构·c++·算法·动态规划·图论