首页 前端知识 vue使用hiprint做打印模板并打印

vue使用hiprint做打印模板并打印

2024-08-12 10:08:27 前端知识 前端哥 461 523 我要收藏

需求:前端能够在很多功能打印,一个打印的单据可能需要多个模板。

hiprint可用将模板保存为字符串。

设计:建立一个模板表;有以下字段:id(唯一键),name(前端显示模板名称),printJson(模板字符串),type(分类-同类的模板在同一个地方显示并可打印),等(做成配置时需要其他条件自己考虑加)

前端统一传值可为两种对象和数组(对象只打印一个,数组有多少条数据打印多少个),这个hiprint会自己判断,可以不管。

下载地址:http://hiprint.io/Content/download/hiprint.zip

刚下载下的hiprint有这些文件

将hiprint文件夹放入public里面

建一个打印页面print.html

<!DOCTYPE html>
<html>

    <head>
        <meta charset="utf-8" />
        <title>自定义打印测试程序</title>
        <!-- hiprint -->
        <link href="hiprint/css/hiprint.css" rel="stylesheet">
        <link href="hiprint/css/print-lock.css" rel="stylesheet">
        <link href="hiprint/css/print-lock.css" media="print" rel="stylesheet">
        <link href="hiprint/bootstrap/bootstrap.min.css" rel="stylesheet">
        <style>
            .hiprint-printPaper{
                border: solid black 1px;
                margin: 10px auto;
            }
        </style>
        <!-- jQuery (hiprint 的所有 JavaScript 插件都依赖 jQuery,所以必须放在前边) -->
        <script src="hiprint/jquery.min.js"></script>
        <script src="hiprint/bootstrap/bootstrap.min.js"></script>
        <!-- 加载 hiprint 的所有 JavaScript 插件。你也可以根据需要只加载单个插件。 -->
        <!-- polyfill.min.js解决浏览器兼容性问题v6.26.0-->
        <script src="hiprint/polyfill.min.js"></script>
        <!-- hiprint 核心js-->
        <script src="hiprint/hiprint.bundle.js"></script>
        <!-- 条形码生成组件-->
        <script src="hiprint/plugins/JsBarcode.all.min.js"></script>
        <!-- 二维码生成组件-->
        <script src="hiprint/plugins/qrcode.js"></script>
        <!-- 调用浏览器打印窗口helper类,可自行替换-->
        <script src="hiprint/plugins/jquery.hiwprint.js"></script>
        <script src="./zhht/Server.js"></script>
        <script src="/src/main.js"></script>
        
    </head>

    <body>
        <div class="btn-group btn-group-justified" role="group" aria-label="...">
            <div class="btn-group" role="group" >
                <button type="button" class="btn btn-default" id="goTemplate" style="background-color: rgb(214, 214, 214);width: 200px;position: fixed;left: 0;top: 0;" onclick="goTemplate()">打印设计</button>
                <button type="button" class="btn btn-default" id="NowPrint" style="background-color: greenyellow;width: 200px;position: fixed;right: 0;top: 0;">立即打印</button>
            </div>
        </div>
        <div id="content">
            <div class="jumbotron">
                <h1 id="Title">正在加载数据请稍后</h1>
                <p id="Describe">正在从服务器中加载数据,请稍后..........</p>
            </div>
        </div>
    </body>
    <script>
        //全局默认对象
        var hiprintTemplate;
        var printData = {} // 打印数据
        var printJson // 打印模板
        const nowPrintTemplate = JSON.parse(sessionStorage.getItem('nowPrintTemplate'))
        if (nowPrintTemplate) {
            printData = nowPrintTemplate.printData
            printJson = nowPrintTemplate.printJson
            console.log('放在缓存里的数据:', nowPrintTemplate);
            GlobalLoading()
        }
        // var Debug = false;
        //全局提前定义好一个叫做LoadPrintDataOk的方法在脚本代码加载完成后调用
        window.LoadPrintDataOk = function(){

        }
        //打印
        function Print(){
            if(hiprintTemplate){
                hiprintTemplate.print(printData);
            }
        }
        //等待页面加载完成后初始化
        // $(document).ready(function(){
        //     TemplateName = ReadURLArgs('TemplateName');
        //     if(TemplateName){
        //         GlobalLoading();
        //     }else{
        //         document.getElementById('Title').innerText = "没有任何有效的模板名称";
        //         document.getElementById('Describe').innerText = "无法从服务器加载任何有效的打印数据?请检查URL地址是否正确";
        //     }

        // });
        //去服务器加载JS脚本
            //加载模板
        function GlobalLoading(){
            // 将当前打印模板打印数据放缓存里
            hiprintTemplate = new hiprint.PrintTemplate ({
                template: JSON.parse(printJson.printJson)
            });
            var printEle = document.getElementById('NowPrint');
            printEle.onclick = Print;
            //将html渲染到页面上
            $("#content").html(hiprintTemplate.getHtml(printData));
        }
        const channel = new BroadcastChannel('zhht_print_channel');
        channel.onmessage = function(event) {
            printData = event.data.printData
            printJson = event.data.printJson
            console.log('放在Channel里的数据:', event.data);
            sessionStorage.setItem('nowPrintTemplate', JSON.stringify({printJson, printData}))
            GlobalLoading()
        }
        // 前往设计页面
        function goTemplate(){
            window.location.assign('/hiprint/custom.html')
        }
    </script>
</html>

在hiprint下的custom.html也就是设计页面的数据改为传进去的数据

保存时保存到后端,写个js文件引用

var url
async function setUrl(){
    try {
        const furl = await fetch('/URLConfig.json')
        const json = furl.json()
        const res = await json.then()
        url = res.baseURL
    } catch (res) {
        console.log(res)
    }
}
setUrl()
//读取本地的Token值
function GetToken(){
    return sessionStorage.getItem('Access-Token')
}
//账户检查
function CheckUser(){
    const userToken = GetToken()
    if(userToken == null){
        alert('当前没有任何账户登录,请再登录后重新保存')
        throw 'User Not Found'
    }else{
        return userToken
    }
}
//根方法
function send(requestParam,succeed,lose){
    const userToken = CheckUser()
    const requestUrl = url + '/api/Print/editDetail'
    const TmpF = fetch(requestUrl, {
        'headers': {
          'accept': 'application/json, text/plain, */*',
          'accept-language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',
          'authorization': 'Bearer '+userToken,
          'cache-control': 'no-cache',
          'content-type': 'application/json',
          'pragma': 'no-cache'
        },
        'body': JSON.stringify(requestParam),
        'method': 'POST',
        'mode': 'cors'
      })
    TmpF.then(resp=>{
        if(resp.status == 200){
            succeed(resp)
        }else{
            lose(resp)
        }
    }).catch(erro => {
        return lose(erro)
    })
}
function queryList(requestParam,succeed,lose){
    send(requestParam,resp=>{
        ServerData(resp,succeed)
    },
    lose)
}
//读取Data中的数据
function ServerData(resp,cb){
    resp.json().then(data=>{
        cb(data)
    })
}

然后再写个组件,弹窗显示打印页面,引用打印页面,传入数据(打印内容与打印模板)

<template>
  <div>
    <a-modal
      v-model="visible"
      centered
      title="打印预览"
      width="90%"
      :maskClosable="false"
      :footer="false"
      :confirm-loading="loading"
      @cancel="cancel">
      <iframe
        v-if="visible"
        src="/print.html"
        width="100%"
        :height="scrollY + 'px'"></iframe>
    </a-modal>
  </div>
</template>
  <script>
  export default {
    name: 'ModelPrint',
    data() {
      return {
        visible: false,
        loading: false,
        printData: null,
        printJson: null,
        scrollY: 0,
        channel: null
      }
    },
    created() {
      this.channel = new BroadcastChannel('zhht_print_channel')
      this.scrollY = document.documentElement.clientHeight - 140
    },
    methods: {
      com() {
        this.channel.postMessage({
          printData: this.printData,
          printJson: this.printJson
        })
      },
      ok() {},
      cancel() {
        sessionStorage.removeItem('nowPrintTemplate')
        this.visible = false
      }
    }
  }
  </script>
  <style scoped></style>
  

然后在要打印的页面使用,我这边是把打印组件封装到表格组件里了,做成了配置项

效果如图:

点击打印调用浏览器打印页面

点击设计进入设计页面,如图

目前还有很大的瑕疵,例如比较复杂的打印模板无法处理、配置比较麻烦等。

转载请注明出处或者链接地址:https://www.qianduange.cn//article/15379.html
标签
评论
发布的文章

jQuery Knob 项目教程

2024-08-19 22:08:18

jquery 实现倒计时

2024-08-19 22:08:06

echarts柱状图属性

2024-08-19 22:08:57

word模版导出(echarts)ftl

2024-08-19 22:08:57

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!