vue3 实现将html内容导出为图片、pdf和word

话不多说直接开始

本文使用到的开源插件库地址 wang1xiang

1.1 下载依赖

复制代码
npm install html2canvas jspdf html-docx-js-typescript file-saver --save

2.1 下载工具

javascript 复制代码
npm install html2image-pdf-word --save

3.1 页面使用

javascript 复制代码
<template>
    <div>
        <div @click="htmlToPdfFn(1)">导出为图片</div>
        <div @click="htmlToPdfFn(2)">导出为pdf</div>
        <div @click="htmlToPdfFn(3)">导出为Word</div>
        <div id="report" style="padding: 40px;">
            <el-table :data="tableData" style="width: 100%">
                <el-table-column type="selection" width="55" />
                <el-table-column label="Date" width="120">
                    <template #default="scope">{{ scope.row.date }}</template>
                </el-table-column>
                <el-table-column property="name" label="Name" width="120" />
                <el-table-column property="address" label="use show-overflow-tooltip" width="240"
                    show-overflow-tooltip />
                <el-table-column property="address" label="address" />
            </el-table>
            <div>
                测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字
            </div>
            <div>
                测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字
            </div>
            <div>
                测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字,测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字
            </div>
        </div>
    </div>
</template>

<script setup lang="ts">
import { exportAsPdf, exportAsWord, exportAsImage } from 'html2image-pdf-word';
interface User {
    date: string
    name: string
    address: string
}
const tableData: User[] = [
    {
        date: '2016-05-04',
        name: 'Aleyna Kutzner',
        address: 'Lohrbergstr. 86c, Süd Lilli, Saarland',
    },
    {
        date: '2016-05-03',
        name: 'Helen Jacobi',
        address: '760 A Street, South Frankfield, Illinois',
    },
    {
        date: '2016-05-02',
        name: 'Brandon Deckert',
        address: 'Arnold-Ohletz-Str. 41a, Alt Malinascheid, Thüringen',
    },
    {
        date: '2016-05-01',
        name: 'Margie Smith',
        address: '23618 Windsor Drive, West Ricardoview, Idaho',
    },
]

let htmlToPdfFn = async (type: number) => {
    const dom: any = document.querySelector('#report');
    const filename = 'test';
    switch (type) {
        case 1:
            await exportAsImage(dom, filename, '水印,水印水印');
            break;
        case 2:
            await exportAsPdf(dom, filename);
            break;
        case 3:
            await exportAsWord(dom, filename);
            break;
    }
}
</script>
<style scoped lang="scss"></style>
相关推荐
m0_50272495几秒前
腾讯地图tlbs-multi-marker动态更新marker图标
前端·javascript·vue.js·地图
itjinyin几秒前
SpringBoot + vue 管理系统
vue.js·spring boot·后端
IT_陈寒5 分钟前
SpringBoot 项目启动慢?这5个优化技巧让你的应用快50%
前端·人工智能·后端
GISer_Jing14 分钟前
React核心语法:组件化与声明式编程
前端·react.js·前端框架
DJ斯特拉14 分钟前
文件上传(UUID防止重名文件&&阿里云实现云端上传&&MultipartFile接收前端文件)
前端
开开心心就好15 分钟前
安卓免费证件照制作软件,无广告弹窗
linux·运维·安全·pdf·迭代器模式·依赖倒置原则·1024程序员节
Alan Lu Pop19 分钟前
React 表单提交关键词意外触发刷新
前端·javascript·react.js
掘金安东尼22 分钟前
企业级Claw落地避坑指南:70%项目失败的真实原因
前端·面试·github
这儿有一堆花22 分钟前
从技术标准到营销概念:深度解析 HTML5 与 H5 的演变与区别
前端·html·html5
我命由我1234522 分钟前
React - 创建 React 项目、React 项目结构、React 简单案例、TodoList 案例
前端·javascript·react.js·前端框架·ecmascript·html5·js