ActiveReportsJs 账票印刷

news2025/1/9 10:12:42

参考资料

  1. 官方文档

一. HTML部分

  • 在页面上添加了Loading效果,账票印刷开始时显示Loading效果,印刷结束后隐藏Loading效果。
  • ar-js-core.js是核心文件
  • ar-js-pdf.js用来印刷PDF
  • ar-js-xlsx.js用来印刷EXCEL
  • ar-js-locales.js用来设置语言
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <style>
        @keyframes donut-spin {
            0% {
                transform: rotate(0deg);
            }
            100% {
                transform: rotate(360deg);
            }
        }
        .donut-container {
            display: flex;
            justify-content: center;
            align-items: center;
            margin-top: 20%;
        }
        .donut {
            display: inline-block;
            border: 4px solid rgba(0, 0, 0, 0.1);
            border-left-color: #7983ff;
            border-radius: 50%;
            width: 30px;
            height: 30px;
            animation: donut-spin 1.2s linear infinite;
        }
        .hidden {
            display: none;
        }
    </style>
    <title>Document</title>
</head>
<body>
    <!-- 账票打印区域 -->
    <div id="container">
        <button id="pdf">打印PDF</button>
        <hr>
        <button id="excel">打印Excel</button>
    </div>

    <!-- loading效果 -->
    <div class="donut-container hidden" id="loading">
        <div class="donut"></div>
    </div>

</body>
<!-- 核心文件 -->
<script src="https://cdn.grapecity.com/activereportsjs/4.0.0/dist/ar-js-core.js"></script>
<!-- 打印PDF -->
<script src="https://cdn.grapecity.com/activereportsjs/4.0.0/dist/ar-js-pdf.js"></script>
<!-- 打印Excel -->
<script src="https://cdn.grapecity.com/activereportsjs/4.0.0/dist/ar-js-xlsx.js"></script>
<!-- 语言 -->
<script src="https://cdn.grapecity.com/activereportsjs/4.0.0/dist/locales/ar-js-locales.js"></script>
</html>

二. 账票定义体

⏹账票定义体本质上就是通过ActiveReportsJS Designer制作的特殊json文件,该json文件用来描述账票的样式,和后台提供的json数据进行绑定。只要后台提供的json数据的格式和账票定义体绑定的json数据格式保持一致,后台的数据便可显示在账票上。

在这里插入图片描述


三. JS部分

  • GC.ActiveReports对象中解构出账票印刷所需的各类对象
  • 账票定义体是后缀为.rdlx-json的文件,本质上是一个json文件。
  • 从后台请求账票印刷所需的json数据,然后通过账票定义体的DataSources[0].ConnectionProperties.ConnectString连接字符串将其放入账票定义体。
  • 可以定义一个配置对象,用来配置印刷账票的相关设置
  • 使用new Intl.DateTimeFormat来获取时间对象
window.addEventListener('load', () => {
   init();
});

function init() {

    document.querySelector("#container").addEventListener("click", async function({target: {id}}) {

        if (!id) {
            return;
        }

        // 显示loading效果
        document.querySelector("#loading").classList.remove("hidden");

        // 从GC(GrapeCity的缩写)对象中,解构出账票打印的对象
        const {
            Core: ARJS,
            PdfExport,
            XlsxExport
        } = GC.ActiveReports;

        // 模拟从后台获取的json数据
        const dataResponse = await fetch('./01-reports/sales_data_sample_2.json');
        const reportJsonData = await dataResponse.json();

        /*
            获取账票的定义体对象,
            该定义体对象一般保存在前台的静态资源文件处
        */ 
        const reportResponse = await fetch('./01-reports/SalesDataByProductLineAndDate.rdlx-json');
        const report = await reportResponse.json();

        // 将后台得到的json数据放到账票定义体中
        report.DataSources[0].ConnectionProperties.ConnectString = "jsondata=" + JSON.stringify(reportJsonData);

        // 根据账票类型进行配置
        const exportCategoryMap = new Map([
            ["pdf", {
                info: {
                    title: 'Invoice List',
                    subject: 'This is the Invoice List',
                    author: 'John K',
                    keywords: 'PDF; import; export'
                }
            }],
            ["excel", {
                info: {
                    creator: '贾飞天'
                },
                // 设置sheet页名称
                sheetName: 'Sheet_Details',
                // 印刷纸张设置
                pageSettings: {
                    size:'A4',
                    orientation: 'landscape'
                },
                // Excel文件设置的密码(该密码可以由后台返回给前台)
                password: 'password'
            }],
        ]);
        const exportSetting = exportCategoryMap.get(id);
        
        // 账票类型的Map映射
        const exportObj = new Map([
            ["pdf", PdfExport],
            ["excel", XlsxExport]
        ]).get(id);

        // 注册字体
        ARJS.FontStore.registerFonts('./02-fonts/fontsConfig.json');
        
        // 加载账票定义体对象
        const pageReport = new ARJS.PageReport({ language: "ja" });
await pageReport.load(report);

        // 获取账票导出对象
        const pageDocument = await pageReport.run();
const result = await exportObj.exportDocument(pageDocument, exportSetting);

        // 账票下载
        result.download(`账票名_${yyyyMMddHHmmssTime()}`);
        
        // 隐藏loading效果
        document.querySelector("#loading").classList.add("hidden");
    });
}

// 构造yyyyMMddHHmmss时间
function yyyyMMddHHmmssTime() {
     return new Intl.DateTimeFormat('jp', {
         	year: 'numeric', 
			month: '2-digit', 
			day: '2-digit',   
			hour: 'numeric',
			hour12: false,  
			minute: 'numeric', 
			second: 'numeric',
			fractionalSecondDigits: 3,
     }).format(new Date())
	   .replaceAll("/", "")
	   .replaceAll(":", "")
	   .replaceAll(" ", "")
	   .replaceAll(".", "");
 }

四. 效果

⏹PDF效果
在这里插入图片描述

⏹Excel效果

在这里插入图片描述


五. Vue用法

⏹package.json

"dependencies": {
	"@grapecity/activereports": "^4.0.2",
	"@grapecity/activereports-localization": "^4.0.2",
 	// ...省略...
},

⏹Vue部分

import { Core, PdfExport, XlsxExport } from "@grapecity/activereports";
import '@grapecity/activereports-localization';
import '@grapecity/activereports/xlsxexport';
import '@grapecity/activereports/pdfexport';
import '@grapecity/activereports';

// 账票印刷部分代码和纯JS代码相同...

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/981955.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL——数据类型以及对表结构的修改

MySQL的数据类型 刚才我们在创建表的时候&#xff0c;说到了一个字段类型&#xff0c;所谓的字段类型就是这个字段能存放的数据的数据类型&#xff0c;在MySQL中有以下几种数据类型&#xff1a; 数据类型 大小&#xff08;字节&#xff09; 用途 格式 INT 4 整数 FLOAT…

13 - 多线程之锁优化(中):深入了解Lock同步锁的优化方法

上一讲介绍了在 JVM 层实现的 Synchronized 同步锁的优化方法&#xff0c;除此之外&#xff0c;在 JDK1.5 之后&#xff0c;Java 还提供了 Lock 同步锁。那么它有什么优势呢&#xff1f; 相对于需要 JVM 隐式获取和释放锁的 Synchronized 同步锁&#xff0c;Lock 同步锁&#…

echarts legend如何控制标签文字长度

效果 代码&#xff0c;直接贴进去换掉就能测试 legend: {type: scroll,top: 10%,icon: circle,right: 5%,orient: vertical,formatter:(name)>{//下面三个值换一下就行let arr [{a| 科创团队 },{b| 10 个},{c| 100 %}]return arr.join( )},textStyle: { color: #C2…

java实现创建时间、修改时间自动生成

一、TbaleMetaObjectHandler package com.ybzx.zdbx.common.handler;import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.reflection.MetaObject; import org.springframework.stereotype.Compo…

一文了解Android App Bundle 格式文件

1. Android App Bundle 是什么&#xff1f; 从 2021 年 8 月起&#xff0c;新应用需要使用 Android App Bundle 才能在 Google Play 中发布。 Android App Bundle是一种发布格式&#xff0c;打包出来的格式为aab&#xff0c;而之前我们打包出来的格式为apk。编写完代码之后&a…

PowerDesginer提示打印机错误

PowerDesginer提示打印机错误 错误信息&#xff1a;在您可以执行与打印机有关的任务(例如页面设置或打印一个文档)之前,您必须已经安装打印机。您想现在安装打印机么&#xff1f; 运行 >services.msc> Print Spooler 启动服务

JSON是什么?认识 json

目录 一 Json定义 二 Json语法规则 三 json 的代码演示 一 Json定义 轻量级的文本数据交换格式具有自我描述性【看到某个Json数据就能知道它的特点】比xml传输速度快【跨平台】 二 Json语法规则 &#xff08;1&#xff09;语法 两种数据结构&#xff1a;对象和数组 大括号…

LGFormer:LOCAL TO GLOBAL TRANSFORMER FOR VIDEO BASED 3D HUMAN POSE ESTIMATION

基于视频的三维人体姿态估计的局部到全局Transformer 作者&#xff1a;马海峰 *&#xff0c;陆克 * †&#xff0c;薛健 *&#xff0c;牛泽海 *&#xff0c;高鹏程† * 中国科学院大学工程学院&#xff0c;北京100049 鹏程实验室&#xff0c;深圳518055 来源&#xff1a;202…

cartographer 学习

cartographer 学习 编译并运行代码 由于cartographer整体分成了两个包 一个是cartographer,不带ros的内容另一个是cartographer_ros&#xff0c;是已ros项目构建的 这样因为带了普通cmake的包&#xff0c;就没法使用catkin_make了&#xff0c;只能使用catkin_make_isolated …

Global mapper24.1最新中文版本教程以及安装包

Global mapper成为如此用户友好的数据编辑、分析等工具的部分原因是它如何处理已删除的要素。从撤消管理器到独立工作空间&#xff0c;已删除的功能并不总是消失。矢量特征以一种简单的方式&#xff0c;当您在需要时遇到它时几乎感觉像魔术一样&#xff0c;矢量特征存储在工作区…

【python基础知识】8.编程思维:如何解决问题-思维篇

文章目录 前言瓶颈1&#xff1a;知识学完就忘用法查询笔记深度理解笔记知识管理 瓶颈2&#xff1a;缺乏解题能力如何解题分析问题&#xff0c;明确结果思考需要的知识&#xff0c;或搜索新知识思考切入点尝试解决问题的一部分尝试重复1-4步 总结 前言 Hi&#xff0c;欢迎来到第…

three.js 纹理

默认情况下&#xff0c;您在 Three.js 中渲染的所有内容都会发送到屏幕上。毕竟&#xff0c;如果你看不到它&#xff0c;渲染它有什么意义呢&#xff1f;事实证明&#xff0c;有一个非常重要的点&#xff1a;在数据发送到屏幕&#xff08;从而丢失&#xff09;之前捕获数据。 …

Apache Doris 2.0 如何实现导入性能提升 2-8 倍

数据导入吞吐是 OLAP 系统性能的重要衡量标准之一&#xff0c;高效的数据导入能力能够加速数据实时处理和分析的效率。随着 Apache Doris 用户规模的不断扩大&#xff0c; 越来越多用户对数据导入提出更高的要求&#xff0c;这也为 Apache Doris 的数据导入能力带来了更大的挑战…

二进制+八进制+十进制+十六进制的转换关系

二进制+八进制+十进制+十六进制的转换关系 1.十进制:由0-9这九个数字组成,逢10进1,我们日常生活中用的就是十进制; 2.二进制:由0和1两个数字组成,逢2进1; 3.八进制:由0-7这8个数字组成,逢8进1; 4.十六进制:由0-9、A、B、C、D、E、F组成,A-F对应的是10-15,逢16进…

【Redis】为什么要学 Redis

文章目录 前言一、Redis 为什么快二、Redis 的特性2.1 将数据储存到内存中2.2 可编程性2.3 可扩展性2.4 持久性2.5 支持集群2.6 高可用性 三、Redis 的应用场景四、不能使用 Redis 的场景 前言 关于为什么要学 Redis 这个问题&#xff0c;一个字就可以回答&#xff0c;那就是&…

创建java文件 自动添加作者、时间等信息 – IDEA 技巧

文章目录 效果修改位置配置信息 效果 每次创建文件的时候&#xff0c;自动加上作者、时间等信息 修改位置 打开&#xff1a;File —> Settings —> Editor —> File and Code Templates —> includes —> FileHeader 配置信息 /*** author : JavaPub 王仕宇* d…

文件包含漏洞实战

加粗样式 文章目录 漏洞原理特点利用方法包含图片木马读取敏感文件 封装协议 复现环境准备漏洞点代码审计验证漏洞点读取敏感文件 文件包含漏洞文件上传漏洞深度利用中国蚁剑-getshell突破文件上传漏洞限制读取文件源码执行PHP命令远程文件包含 文件包含漏洞防御 本次测试仅供…

SMB 协议详解之-SMB1文件写入交互过程详解

本文介绍一下SMB协议的交互过程。由于SMB涉及非常多的字段,绝大多数人员没有必要对每个字段进行深入的了解(那可能更多的是协议开发人员需要做的工作)。对于SMB协议的学习,主要的目的是能够根据数据包的交互过程,还原出这次SMB交互干了什么,产生了哪些操作。因此本文聚焦…

centos执行systemctl restart命令报连接超时

centos执行systemctl restart命令报连接超时 Error getting authority: Error initializing authority: Error calling StartServiceByName for org.freedesktop.PolicyKit1: GDBus.Error:org.freedesktop.DBus.Error.TimedOut: Activation of org.freedesktop.PolicyKit1 tim…

LeetCode 18 四数之和

题目链接 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 题目解析 固定两个数&#xff0c;然后利用双指针来进行剩下两个数的筛选 主要使用的是三数之和的思想&#xff0c;具体可以看我上篇博客 注意去重 代码 class Solution { public:vector<…