IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 浏览器打印长table时按页拆分 -> 正文阅读

[JavaScript知识库]浏览器打印长table时按页拆分

需求

  1. 浏览器中打印 高度未知的复杂table, 如果不做任何处理,使用 window.print() 打印 则打印中因为不存在断行. 多张纸中不美观. 需要按A4纸高度 拆分table的行进行打印
解决方案
  1. 获取所有的行标签tr元素
  2. 通过循环tr元素 和 getBoundingClientRect 获取 元素与整个table 左上角的距离
  3. 如果距离高度超过了1页纸的高度 则直接在此tr元素前插入一个指定高度的div. 达到分页效果

基础知识

function splitPage(config){
  let totalDom = document.getElementById('printDom'); // 需要打印的table
  const {
    insertDomHeight = '3cm',
    paperHeight = 29,
    printPageIds = [], // table元素id 支持多个table 同时打印. 
  } = config;

  const onePageHeightPixes = Math.ceil(96 * paperHeight / 2.54);   // 一张纸 的高度(像素)
  // https://developer.mozilla.org/zh-CN/docs/Web/CSS/length  1cm = 96px / 2.54
  // A4纸 29.7cm 高

  const { top : totalTop, height : totalHeight  } = totalDom.getBoundingClientRect();
  let insertHeight = onePageHeightPixes;
for (let item of printPageIds) {
    const trList = document.querySelectorAll(`tr[data-tr-id*="${item}"]`);
    if (trList) {
      trList.forEach((x) => {
        const nodePosition = x.getBoundingClientRect();
        const { top, height } = nodePosition;
        const distance = top + height - totalTop; // 目标元素左下角相对于整个表单左上角的距离;
        if (distance > insertHeight) {
          const divHeight = top - insertHeight + height + insertDomHeight;
          console.log(divHeight);
          insertDiv(x, divHeight + 'px');
          insertHeight = insertHeight + onePageHeightPixes;
        }
      });
    }
  }

}


function insertDiv(dom, height = '5cm'){
  if (!dom) {
    return;
  }
  let parent = dom.parentNode;
  let newNode = document.createElement("div");
  newNode.style.height = height;
  parent.insertBefore(newNode, dom);
}

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-26 11:33:45  更:2022-04-26 11:36:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 2:17:16-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码