Skip to content

一款智能打印插件,目标是处理表格的打印,实现自定义页头、页尾、水印、分页方式等

Notifications You must be signed in to change notification settings

shanjing-inc/table-print

 
 

Repository files navigation

Page Views Count. react js+dom vue

简介

js-table-print是一款智能打印插件,目标是处理表格的打印,实现自定义页头、页尾、水印、分页方式等

环境支持

1、react
2、原生js+dom

功能列表

1、设定某些DOM节点组成一组,必须打印在同一张页面内,如果被切割则会重新分页打印。
2、提供页头和页尾样式,也可自定义样式。
3、提供分页出的水印样式,也可自定义样式。
4、可调整页边距
5、可设定横向或纵向打印
6、样式完全根据当前页面样式打印,无需再次单独导入css

预览图

review.jpg

install

npm install js-table-print

usage

let plugin = new TablePrint({
  children:domTable,
  footer:true,
  water:true,
});
setTimeout(()=>{
  plugin.print();
},0)

with React

import TablePrint from 'js-table-print';

class Demo extends React.Component {
  constructor(props) {
    super(props);
  }

  onPrint(){
    let table = React.createElement(Table,{},null)
    let domTable = document.createElement('section');
    domTable.style.display='contents';
    ReactDOM.render(table, domTable);
  
    let plugin = new TablePrint({
      children:domTable.children[0].children,
      footer:true,
      water:true,
    });
    setTimeout(()=>{
      plugin.print();
    },0)
  }
    
  render() {
    return (
      <div>
        <div onClick={this.onPrint.bind(this)}>点击生成表单并打印</div>
      </div>
    );
  }
}


class Table extends React.Component{
  constructor(props) {
    super(props);
  }

  render(){
    const {list} = this.state;
    return (
      <section>
        <h1>
          产品申请单
          <span>2021-01-01</span>
        </h1>
        <table >
          <thead></thead>
          <tbody >
            <tr>
              <td>申请人</td>
              <td>测试人</td>
              <td>申请人部门</td>
              <td>测试部门</td>
            </tr>
            <tr>
              <td>总额</td>
              <td>¥123.00</td>
              <td>备注</td>
              <td>123123</td>
            </tr>
          </tbody>
        </table>
        <hgroup>
          <div>确认签字</div>
          <table>
            <thead></thead>
            <tbody>
              <tr>
                <td>申请人</td>
                <td></td>
                <td>收单人</td>
                <td></td>
              </tr>
              <tr>
                <td>上级审批</td>
                <td></td>
                <td>CEO确认</td>
                <td></td>
              </tr>
            </tbody>
          </table>
        </hgroup>
     </section>
    )
  }
}

ReactDOM.render(<Demo />, document.getElementById("container"));

with javascript

<script src="js-table-print.js"></script>
<link rel="stylesheet" type="text/css" href='mytable.css' />

var table=`
<h1>
  产品申请单
  <span>2021-01-01</span>
</h1>
<table >
  <thead></thead>
  <tbody >
    <tr>
      <td>申请人</td>
      <td>测试人</td>
      <td>申请人部门</td>
      <td>测试部门</td>
    </tr>
    <tr>
      <td>总额</td>
      <td>¥123.00</td>
      <td>备注</td>
      <td>123123</td>
    </tr>
  </tbody>
</table>
<hgroup>
  <div>确认签字</div>
  <table>
    <thead></thead>
    <tbody>
      <tr>
        <td>申请人</td>
        <td></td>
        <td>收单人</td>
        <td></td>
      </tr>
      <tr>
        <td>上级审批</td>
        <td></td>
        <td>CEO确认</td>
        <td></td>
      </tr>
    </tbody>
  </table>
</hgroup>
`
document.body.innerHTML = table;

var TablePrint = TablePrint||window['js-table-print'].default;
let plugin = new TablePrint({
  children:document.body.children,
  footer:true,
  water:true,
});
setTimeout(()=>{
  plugin.print();
},0)

children元素的规范

1、在表格绘制时,使用如下格式规范进行填充,其中如果没有表头也需要保留表头标签<thead></thead> 2、可以给标签添加style或class样式

<table>
  <thead>
    <tr>
      <th>标题1</th>
      <th>标题2</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>列1</td>
      <td>列2</td>
    </tr>
    <tr>
      <td>列1</td>
      <td>列2</td>
    </tr>
  </tbody>
</table>

3、将一组需要始终保持在一个页面内打印的内容,放在一个dom下,比如,如果希望下面2个dom在打印时始终打印在一张A4纸上不被分开,则必须将他们放在一个DOM组下

<section>
  123123
  123123
</section>
<section>
  abc
  abc
</section>

修改后:

<hgroup>
  <section>
    123123
    123123
  </section>
  <section>
    abc
    abc
  </section>
</hgroup>

4、整个children的内容可以大致如下:

<h1>标题</h1>
<table>
  <thead>
    <tr>
      <th>标题1</th>
      <th>标题2</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>列1</td>
      <td>列2</td>
    </tr>
    <tr>
      <td>列1</td>
      <td>列2</td>
    </tr>
  </tbody>
</table>
<h3>分隔标题</h3>
<!-- 这个hgroup内的内容打印时会确保打印在一张纸上 -->
<hgroup> 
  <table>
    <thead></thead>
    <tbody>
      <tr>
        <td>申请人</td>
        <td></td>
      </tr>
      <tr>
        <td>收款人</td>
        <td></td>
      </tr>
    </tbody>
  </table>
</hgroup>

Config

参数 说明 类型 默认值
landscape 是否为横向布局 boolean false
padding 页边距 String 40
footer 页脚 boolean|Dom false
header 页头 boolean|Dom false
children 打印的内容 [Documents] -
water 分页水印 boolean|Document false
waterHeight 水印高度 Number -

开发者环境

node:10.15.0
npm:6.14.5

更新日志

  • v1.0.0 发布

About

一款智能打印插件,目标是处理表格的打印,实现自定义页头、页尾、水印、分页方式等

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 76.6%
  • SCSS 12.1%
  • HTML 10.6%
  • Shell 0.7%