Vue3+hooks快速接入Lodop打印插件

2023-12-17 19:45

本文主要是介绍Vue3+hooks快速接入Lodop打印插件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、下载并修改LodopFuncs.js
    • 1.1 调整LodopFuncs.js代码, 暴露 getLodop
  • 二、自定义useLodop hooks抽取共用的lodop逻辑
    • CheckLodopIsOk
    • getPrinterArr
    • printLabel
    • printA4Paper
  • 总结


前言

上面文章《Vue快速接入菜鸟打印组件》讲了vue3如何快速集成菜鸟打印组件,这篇讲讲vue3如何集成lodop组件。


一、下载并修改LodopFuncs.js

在官网 Lodop 官网 下载入门案例,其中有LodopFuncs.js

在这里插入图片描述
我们需要的文件 LodopFuncs.js ,其他案例也可以稍微运行看看。
在这里插入图片描述

1.1 调整LodopFuncs.js代码, 暴露 getLodop

我们在尾部加上一下代码,暴露Lodop的初始化函数。

export { getLodop }

在这里插入图片描述

二、自定义useLodop hooks抽取共用的lodop逻辑

在项目的hooks 文件夹下创建一个hook。根据自己的项目,按实际情况命名。
这里是 useLodop.ts

// 引入上一步骤创建的lodopfuns
import { getLodop } from '@/utils/lodop/LodopFuncs'
import { reactive } from 'vue'
import { ElMessage } from 'element-plus'export function useLodop() {const variable = reactive({printerArr: []})let LODOP = nullconst CheckLodopIsOk = async () => {try {LODOP = getLodop()if (LODOP.VERSION) {if (LODOP.CVERSION) {return true} else {return true}}} catch (err) {return false}}const printLabel = async (options: {strBASE64Code: stringxxxx: stringrawRow: {paperType: PaperTypeEnum}}) => {LODOP = getLodop()if (!LODOP) {return ElMessage.warning('请安装/启动Lodop 打印插件')}LODOP.PRINT_INIT('')// 根据打印的类型,获取设置的打印机字符串。根据自己的实际业务修改const printerStr = await getPrinter(options?.xxx, options?.rawRow?.paperType)if (!LODOP.SET_PRINTER_INDEX(printerStr)) {return Promise.resolve(false)}if ((options.rawRow.paperType ) == 'Label_4X6') {LODOP.SET_PRINT_PAGESIZE(1, '100mm', '152.4mm', '') // 纸张方向大小} else {LODOP.SET_PRINT_PAGESIZE(3, '', '', 'A4') // 纸张方向大小}LODOP.ADD_PRINT_IMAGE(0, 0, '100%', '100%', options?.strBASE64Code)// 设置打印的显示比例LODOP.SET_PRINT_STYLEA(0, 'Stretch', 1)// LODOP.PREVIEW();const isPrintSuccess = LODOP.PRINT()return Promise.resolve(!!isPrintSuccess )}const printA4Paper = async (options: {rawObj: Objectxxxx: stringTableId: string}) => {LODOP = getLodop()if (!LODOP) {return ElMessage.warning('请安装/启动Lodop 打印插件')}LODOP.PRINT_INIT('')const printerStr = await getPrinter(options?.xxxx, 'A4')if (!LODOP.SET_PRINTER_INDEX(printerStr)) {return Promise.resolve(false)}// 条形码LODOP.ADD_PRINT_BARCODE('20mm', 32, '40%', 100, '128B', `${options.rawObj?.barcode}`)LODOP.SET_PRINT_STYLEA(0, 'ItemType', 1)// LODOP.ADD_PRINT_BARCODE(5,734,168,146,"QRCode","1234567890版本7的最大值是122个字符123123");LODOP.SET_PRINT_STYLE('FontSize', 12)LODOP.SET_PRINT_PAGESIZE(3, 0, 0, 'A4') // 纸张方向大小LODOP.SET_PRINT_STYLEA(0, 'TableHeightScope', 3) //高度包含页尾//  ADD_PRINT_HTM(intTop,intLeft,intWidth,intHeight,strHtml)增加超文本项LODOP.SET_PRINT_COPIES(1) // 份数// LODOP.SET_PRINT_STYLE('Bold', 1)LODOP.SET_PRINT_STYLE('FontSize', '12')LODOP.ADD_PRINT_TEXT('20mm','115mm','100mm','5mm',`Warehouse:${options.rawObj?.baseWarehouseVo?.name}`)// 放在某处后面表示每一页都有这个内容 , 类似页眉页脚用法LODOP.SET_PRINT_STYLEA(0, 'ItemType', 1)}// 表格部分LODOP.ADD_PRINT_HTM('59mm','0mm','RightMargin:2mm','100%',document.getElementById(`${options.TableId}`).innerHTML)// LODOP.ADD_PRINT_TABLE(//   '59mm',//   '0mm',//   '198mm',//   '275mm',//   document.getElementById(`${options.TableId}`)?.innerHTML// )// 页码LODOP.ADD_PRINT_HTM('6mm','90%','100mm',20,"<span tdata='pageNO'>##</span> of <span tdata='pageCount'> ##</span>")LODOP.SET_PRINT_STYLEA(0, 'ItemType', 1)const isPrintSuccss = LODOP.PRINT() // 直接打印return Promise.resolve(!!isPrintSuccss)}const getPrinterArr = () => {variable.printerArr = []if (!CheckLodopIsOk()) {ElMessage.warning('请安装/启动Lodop打印插件')return false}let counter = LODOP.GET_PRINTER_COUNT() // 获取打印机个数for (let i = 0; i < counter; i++) {var curPrintName = LODOP.GET_PRINTER_NAME(i)variable.printerArr.push({name: curPrintName,label: curPrintName})}localStorage.setItem('PRINTER_ARR', JSON.stringify(variable.printerArr || []))return true}return {getPrinterArr,printLabel,printA4Paper,CheckLodopIsOk}
}

上述代码大概暴露4个方法分别为

CheckLodopIsOk

CheckLodopIsOk : 判断lodop 插件是否安装、启动了,相应的逻辑处理,一般插件都没开启直接提示就好

getPrinterArr

getPrinterArr :这个是判断有没有可以用打印机,需要安装了lodop插件后,调用他的api 获取。这里获取后储存了起来方便其他页面调用

printLabel

printLabel : 这个方法用来处理base64 数据,打印标签, 其中 LODOP.SET_PRINT_STYLEA(0, ‘Stretch’, 1) 用来调整显示比例

printA4Paper

printA4Paper: 这个是打印A4纸质的表单,常见的仓库里的拣货单等


总结

本文讲解Vue3 项目如何从零到1集成lodop 实现标签打印与A4纸质类型的打印。

这篇关于Vue3+hooks快速接入Lodop打印插件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/505614

相关文章

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,