当前位置: 首页 > article >正文

Vxe vue vxe-table 分享实现打印表格以及同时打印两张表

Vxe vue vxe-table 分享实现打印表格以及同时打印两张表

vxe-table 默认情况下支持单表打印。
在有些情况下,页面上同时有几张表,这时需要一次性打印出来。可以利用 Vxe 自带的分页打印功能,实现多张表同时打印。

效果

在这里插入图片描述
点击打印后自动调起预览,可以直接连接打印机或者导出PDF
在这里插入图片描述
在这里插入图片描述

代码

实现步骤,
第一步:渲染表格
第二步:通过表格实例的 getPrintHtml() 方法获取打印的 html,不管有几张表都行, 有几张表就调用几次。
第三步:将结构转成分页打印,调用 VxeUI.print 打印

<template>
  <div>
    <vxe-button @click="printEvent">同时打印2张表</vxe-button>

    <vxe-table
      border
      height="300"
      ref="table1Ref"
      :data="tableData1">
      <vxe-column field="id" title="ID" width="60"></vxe-column>
      <vxe-column field="name" title="Name"></vxe-column>
      <vxe-column field="sex" title="Sex"></vxe-column>
      <vxe-column field="address" title="Address"></vxe-column>
    </vxe-table>

    <vxe-table
      border
      height="300"
      ref="table2Ref"
      :data="tableData2">
      <vxe-column field="id" title="ID" width="60"></vxe-column>
      <vxe-column field="role" title="Role"></vxe-column>
      <vxe-column field="age" title="Age"></vxe-column>
    </vxe-table>
  </div>
</template>

<script setup>
import { ref } from 'vue'
import { VxeUI } from 'vxe-pc-ui'
const table1Ref = ref()
const table2Ref = ref()
const tableData1 = ref([
  { id: 10001, name: 'Test1', role: 'Develop', sex: 'Man', age: 28, address: 'test abc' },
  { id: 10002, name: 'Test2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou' },
  { id: 10003, name: 'Test3', role: 'PM', sex: 'Man', age: 32, address: 'Shanghai' },
  { id: 10004, name: 'Test4', role: 'Designer', sex: 'Women', age: 24, address: 'Shanghai' }
])
const tableData2 = ref([
  { id: 10001, name: 'Test1', role: 'Develop', sex: 'Man', age: 28, address: 'test abc' },
  { id: 10002, name: 'Test2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou' },
  { id: 10003, name: 'Test3', role: 'PM', sex: 'Man', age: 32, address: 'Shanghai' },
  { id: 10004, name: 'Test4', role: 'Designer', sex: 'Women', age: 24, address: 'Shanghai' },
  { id: 10005, name: 'Test5', role: 'PM', sex: 'Man', age: 29, address: 'Shanghai' },
  { id: 10006, name: 'Test6', role: 'Designer', sex: 'Women', age: 38, address: 'Shanghai' }
])
const printEvent = () => {
  const $table1 = table1Ref.value
  const $table2 = table2Ref.value
  if ($table1 && $table2) {
    Promise.all([
      $table1.getPrintHtml().then(({ html }) => {
        return {
          headerHtml: '<div style="text-align: center;font-size: 28px;">第一张表</div>',
          bodyHtml: html
        }
      }),
      $table2.getPrintHtml().then(({ html }) => {
        return {
          headerHtml: '<div style="text-align: center;font-size: 28px;">第二张表</div>',
          bodyHtml: html
        }
      })
    ]).then(pageBreaks => {
      VxeUI.print({
        title: '打印多张表',
        showPageNumber: true,
        pageBreaks
      })
    })
  }
}

</script>


http://www.kler.cn/news/362021.html

相关文章:

  • 《云计算网络技术与应用》实训6-1:配置KVM虚拟机使用NAT网络
  • GJB438C-2021《软件需求规格说明》的一处修订
  • 机器人学 目录
  • Excel重新踩坑3:条件格式;基本公式运算符;公式中的单元格引用方式;公式菜单栏其他有用的功能说明;
  • JavaScript 中如何实现函数缓存
  • Vue+TypeScript+SpringBoot的WebSocket基础教学
  • uniapp结合uview-ui创建项目
  • 基于Prompt工程优化bot
  • 养老院网站毕设计算机毕业设计基于SpringBootSSM框架
  • C#使用XML文件的详解及示例
  • python 更换pip源
  • WordPress中最值得推荐的AI插件:进阶级指南
  • 闯关leetcode——111. Minimum Depth of Binary Tree
  • juzigei/基于Java语言的充电桩系统(充电桩小程序+充电桩管理平台)
  • c++初阶数据结构速成
  • 监控易监测对象及指标之:东方通中间件JMX监控
  • Collection 单列集合 List Set
  • 【含文档】基于ssm+jsp的汉服商城网站 (含源码+数据库+lw)
  • 基于图像加密解密算法
  • 专题十三_记忆化搜索_算法专题详细总结
  • 目标检测系统中需要【重新训练模型】说明
  • LeetCode122:买卖股票的最佳时机II
  • 力扣力扣力:206. 反转链表
  • java项目结构说明
  • scrapy的xpath在控制台可以匹配,但是到了代码无法匹配(无法匹配tbody标签)
  • 金融行业:办公安全防护专属攻略