vue-plugin-hiprint vue hiprint vue使用hiprint打印控件VUE HiPrint HiPrint简单使用

news2024/11/17 5:48:02

vue-plugin-hiprint vue hiprint vue使用hiprint打印控件VUE HiPrint HiPrint简单使用

  • 安装相关依赖
    • 安装 vue-plugin-hiprint
    • JQuery
    • 安装 打印客户端
  • 引入依赖
  • 打印 html 内容 - 简单使用
  • 根据模版打印 - 简单使用
  • 以下内容 和上面demo 没关系 !!!!
  • 修改文本样式
  • 官方所有 打印示例

安装相关依赖

安装 vue-plugin-hiprint

npm install vue-plugin-hiprint

JQuery

因为 vue-plugin-hiprint 使用到了 JQuery 所以需要安装对应依赖

npm i jquery --save-d

安装 打印客户端

根据自己的系统 安装,静默打印才需要用到
在这里插入图片描述

引入依赖

在 main.js 中引入 依赖

/**
 * 打印插件 Hi Print <a href="https://github.com/CcSimple/vue-plugin-hiprint">参考地址</a>
 */

import { hiPrintPlugin } from 'vue-plugin-hiprint'
// hiPrintPlugin.disAutoConnect() // 取消自动连接直接打印客户端,如果设置了取消自动连接,后续是获取不到打印机列表的
Vue.use(hiPrintPlugin, '$pluginName')
/**
 * 将Jquery挂载到 Vue实例中
 */

import jquery from 'jquery'
Vue.prototype.$ = jquery

打印 html 内容 - 简单使用

我这边的 demo是 打印条形码,其他的也差不多,纸张大小是 宽 18.9 毫米 高 9毫米

打印机纸张大小:
在这里插入图片描述

设计面板大小:

在这里插入图片描述

如果 打印出来 比较大,可以将 设计面板 宽 高 都设置比 打印机纸张小一点

实际效果:
在这里插入图片描述
完整代码

<!-- 标签设计页面 -->
<template>
  <div>
  		<button @click="getPrinterList">获取打印机列表</button>
  		<button @click="confirmPrintPrint">打印</button>
        <div id="printDiv" v-print="'#printDiv'" style="display: none;">
        <!-- 这里打印内容 style 内容大小一定要小于 实际纸张大小,如果打印的纸张够大 可以忽略 -->
          <div style="zoom: 1.1;display: inline-block;width: 18mm;height: 7mm;margin-left: 5px;">
            <img src="" style="width: 100%; height: 100%;">
          </div>
        </div>
  </div>
</template>

<script>
// 这里可以导入其他文件(比如:组件,工具js,第三方插件js,json文件,图片文件等等)
// 例如:import 《组件名称》 from '《组件路径》';
import request from '@/utils/request'
import { defaultElementTypeProvider } from 'vue-plugin-hiprint'
export default {
// 组件名称
  name: 'LabelDesignIndex',
  // import引入的组件需要注入到对象中才能使用
  components: {},
  // 父组件传递值
  props: {
  },
  data() {
    // 这里存放数据
    return {
    hiprintTemplate: {}
    }
  },
  // 监听属性 类似于data概念
  computed: {},
  // 监控data中的数据变化
  watch: {},
  // 生命周期 - 创建完成(可以访问当前this实例)
  created() {
  },
  // 生命周期 - 挂载完成(可以访问DOM元素)
  mounted() {
	this.init()
  },
  beforeCreate() {}, // 生命周期 - 创建之前
  beforeMount() {}, // 生命周期 - 挂载之前
  beforeUpdate() {}, // 生命周期 - 更新之前
  updated() {}, // 生命周期 - 更新之后
  beforeDestroy() {}, // 生命周期 - 销毁之前
  destroyed() {}, // 生命周期 - 销毁完成
  activated() {},
  // 方法集合
  methods: {
      // 初始化
    init() {
      // 初始化 打印对象
      const hiprintTemplate_ = new this.$pluginName.PrintTemplate()
      this.hiprintTemplate = hiprintTemplate_
    },
    // 获取打印机列表
    getPrinterList() {
      if (window.hiwebSocket.opened === false) {
        this.$notify.error('打印机客户端未连接')
      }
      // 模板对象获取
      const printerList_ = this.hiprintTemplate.getPrinterList()
      console.info(printerList_)
    },
    // 使用 hiPrintPlugin 控件打印
    confirmPrintPrint() {
    
     // 如果在 main.js 中设置了取消自动连接客户端 是获取不到打印机列表的!!!
     if (window.hiwebSocket.opened === false) {
        this.$notify.error('打印机客户端未连接,请点击右上角头像下载打印客户端')
      }
      
      // 这一句代码 如果打印出来有问题 可以尝试加进去,没有出现 则不用加
      // 初始化 provider
      this.$pluginName.init({
        providers: [defaultElementTypeProvider()]
      })
      
      // 这一句代码 如果打印出来有问题 可以尝试加进去,没有出现 则不用加
      this.$pluginName.PrintElementTypeManager.buildByHtml(this.$('.ep-draggable-item'))

      // 不要使用 this.hiprintTemplate 打印,会出现重复打印,如果要用,请每次打印 都清空内容
      const hiprintTemplate_ = new this.$pluginName.PrintTemplate()
      const panel = hiprintTemplate_.addPrintPanel({
        'height': 9,
        'width': 20,
        'paperHeader': 0,
        'paperFooter': 30,
        'paperNumberLeft': 26,
        'paperNumberTop': 6,
        'paperNumberDisabled': true,
        'orient': 1,
        'scale': 1
      })
      // 这一块代码是可以 放在 create 页面创建完成后 
      // 打印html内容
      panel.addPrintHtml({ options: { width: 20, height: 9, top: 0, left: 0, content: this.$('#printDiv').html() }})
      
      // 预览打印
      hiprintTemplate_ .print()
      
      
      //  打印机列表
      const printerList = hiprintTemplate_ .getPrinterList()
      console.info('打印机列表', printerList)
      
	  // 直接打印 - 不带参数
	  hiprintTemplate_ .print2()
	  
	 // 直接打印 带参数
	  hiprintTemplate_ ntTemplate.print2(null, {
		  printer: '', // 指定打印机 打印机 名称
		  title: '打印任务名称',
		  color: false, // 是否打印颜色 默认 true
		  copies: 1, // 打印份数 默认 1
		});
	  
    }
  } 
}
</script>
<style lang='scss' scoped>
/**scoped 表示样式只在当前组件有效*/
</style>

具体更多打印api文档: 打印api

根据模版打印 - 简单使用

<!-- 标签设计页面 -->
<template>
  <div>
  		<button @click="getPrinterList">获取打印机列表</button>
  		<button @click="confirmPrintPrint">打印</button>
        <!-- 这里打印内容 style 内容大小一定要小于 实际纸张大小,如果打印的纸张够大 可以忽略 -->
        <!-- 打印内容 -->
       	<div id="printDivXm3" />
  </div>
</template>

<script>
// 这里可以导入其他文件(比如:组件,工具js,第三方插件js,json文件,图片文件等等)
// 例如:import 《组件名称》 from '《组件路径》';
import request from '@/utils/request'
import { defaultElementTypeProvider } from 'vue-plugin-hiprint'
export default {
// 组件名称
  name: 'LabelDesignIndex',
  // import引入的组件需要注入到对象中才能使用
  components: {},
  // 父组件传递值
  props: {
  },
  data() {
    // 这里存放数据
    return {
    hiprintTemplate: {}
    }
  },
  // 监听属性 类似于data概念
  computed: {},
  // 监控data中的数据变化
  watch: {},
  // 生命周期 - 创建完成(可以访问当前this实例)
  created() {
  },
  // 生命周期 - 挂载完成(可以访问DOM元素)
  mounted() {
	this.init()
  },
  beforeCreate() {}, // 生命周期 - 创建之前
  beforeMount() {}, // 生命周期 - 挂载之前
  beforeUpdate() {}, // 生命周期 - 更新之前
  updated() {}, // 生命周期 - 更新之后
  beforeDestroy() {}, // 生命周期 - 销毁之前
  destroyed() {}, // 生命周期 - 销毁完成
  activated() {},
  // 方法集合
  methods: {
      // 初始化
    init() {
      // 初始化 打印对象
      const hiprintTemplate_ = new this.$pluginName.PrintTemplate()
      this.hiprintTemplate = hiprintTemplate_
    },
    // 获取打印机列表
    getPrinterList() {
      if (window.hiwebSocket.opened === false) {
        this.$notify.error('打印机客户端未连接')
      }
      // 模板对象获取
      const printerList_ = this.hiprintTemplate.getPrinterList()
      console.info(printerList_)
    },

    // 使用 hiPrintPlugin 控件打印
    confirmPrintPrint() {
    
     // 如果在 main.js 中设置了取消自动连接客户端 是获取不到打印机列表的!!!
     if (window.hiwebSocket.opened === false) {
        this.$notify.error('打印机客户端未连接,请点击右上角头像下载打印客户端')
      }

      // 这一句代码 如果打印出来有问题 可以尝试加进去,没有出现 则不用加
      // 初始化 provider
      this.$pluginName.init({
        providers: [defaultElementTypeProvider()]
      })
      // 这一句代码 如果打印出来有问题 可以尝试加进去,没有出现 则不用加
      this.$pluginName.PrintElementTypeManager.buildByHtml(this.$('.ep-draggable-item'))
	
	
      // 清空原内容
      this.$('#printDivXm3').empty()

      // 不使用全局对象, 使用模版打印,在线设计模版:https://ccsimple.gitee.io/vue-plugin-hiprint/
      const hiprintTemplate_ = new this.$pluginName.PrintTemplate({
        template: {
          'panels': [
            {
              'index': 0,
              'name': 1,
              'height': 38,
              'width': 45,
              'paperHeader': 3,
              'paperFooter': 101.175,
              'printElements': [
                {
                  'options': {
                    'left': 4.5,
                    'top': 15,
                    'height': 21,
                    'width': 118.5,
                    'field': 'boxNumberBarCode',
                    'testData': '',
                    'fontSize': 12,
                    'lineHeight': 18,
                    'textType': 'barcode',
                    'title': '箱号',
                    'right': 121.49514770507812,
                    'bottom': 26.996349334716797,
                    'vCenter': 62.245147705078125,
                    'hCenter': 16.496349334716797,
                    'coordinateSync': false,
                    'widthHeightSync': false,
                    'hideTitle': true,
                    'textAlign': 'center',
                    'qrCodeLevel': 0
                  },
                  'printElementType': {
                    'title': '条形码',
                    'type': 'text'
                  }
                },
                {
                  'options': {
                    'left': 3,
                    'top': 43.5,
                    'height': 9.75,
                    'width': 120,
                    'title': '箱号',
                    'right': 122.99514770507812,
                    'bottom': 44.24878692626953,
                    'vCenter': 62.995147705078125,
                    'hCenter': 39.37378692626953,
                    'field': 'boxNumber',
                    'testData': '124322023031302',
                    'coordinateSync': false,
                    'widthHeightSync': false,
                    'textAlign': 'center',
                    'qrCodeLevel': 0
                  },
                  'printElementType': {
                    'title': '文本',
                    'type': 'text'
                  }
                },
                {
                  'options': {
                    'left': 3,
                    'top': 58.5,
                    'height': 9.75,
                    'width': 120,
                    'title': 'MODEL',
                    'field': 'model',
                    'testData': '4.4>XLR',
                    'coordinateSync': false,
                    'widthHeightSync': false,
                    'textAlign': 'center',
                    'qrCodeLevel': 0,
                    'right': 122.99514770507812,
                    'bottom': 62.2500114440918,
                    'vCenter': 62.995147705078125,
                    'hCenter': 57.3750114440918
                  },
                  'printElementType': {
                    'title': '文本',
                    'type': 'text'
                  }
                },
                {
                  'options': {
                    'left': 3,
                    'top': 75,
                    'height': 9.75,
                    'width': 52.5,
                    'title': 'QTY',
                    'right': 122.99514770507812,
                    'bottom': 81.74878692626953,
                    'vCenter': 62.995147705078125,
                    'hCenter': 76.87378692626953,
                    'field': 'qty',
                    'testData': '300',
                    'coordinateSync': false,
                    'widthHeightSync': false,
                    'qrCodeLevel': 0
                  },
                  'printElementType': {
                    'title': '文本',
                    'type': 'text'
                  }
                },
                {
                  'options': {
                    'left': 64.5,
                    'top': 75,
                    'height': 9.75,
                    'width': 60,
                    'title': 'TO',
                    'right': 111,
                    'bottom': 107.24878692626953,
                    'vCenter': 81,
                    'hCenter': 102.37378692626953,
                    'field': 'language',
                    'testData': '英文',
                    'coordinateSync': false,
                    'widthHeightSync': false,
                    'qrCodeLevel': 0
                  },
                  'printElementType': {
                    'title': '文本',
                    'type': 'text'
                  }
                },
                {
                  'options': {
                    'left': 3,
                    'top': 90,
                    'height': 9.75,
                    'width': 120,
                    'title': '日期',
                    'field': 'date',
                    'testData': '2023-03-15',
                    'coordinateSync': false,
                    'widthHeightSync': false,
                    'textAlign': 'center',
                    'qrCodeLevel': 0
                  },
                  'printElementType': {
                    'title': '文本',
                    'type': 'text'
                  }
                }
              ],
              'paperNumberLeft': 96,
              'paperNumberTop': 82.5,
              'paperNumberDisabled': true,
              'orient': 1
            }
          ]
        }
      })

      // 挂载打印内容
      hiprintTemplate_.design('#printDivXm3')

      // 打印数据,要和 上面 panel 内的 field 参数一致
      const printData = {
        boxNumberBarCode: '我是条形码内容',
        boxNumber: '我是测试内容1',
        model: '我是测试内容2',
        qty: '我是测试内容3',
        language: '我是测试内容4',
        date: '2023-03-15'
      }
      
      // 预览打印
      hiprintTemplate_.print(printData)
	  
	 // 直接打印 带参数
	  hiprintTemplate_ ntTemplate.print2(printData, {
		  printer: '', // 指定打印机 打印机 名称
		  title: '打印任务名称',
		  color: false, // 是否打印颜色 默认 true
		  copies: 1, // 打印份数 默认 1
		});
	  
    }
  } 
}
</script>
<style lang='scss' scoped>
/**scoped 表示样式只在当前组件有效*/
</style>

以下内容 和上面demo 没关系 !!!!

修改文本样式

进入 模版设计 模版设计
在这里插入图片描述

设计好模版 点击 查看模板Json
在这里插入图片描述
在这里插入图片描述
将 font 元素 加入到 option中,例如

      panel.addPrintText({ options: { 'left': 10, 'top': 5, 'height': 15, 'width': 127.5, 'field': 'canshu1', 'testData': '测试数据', 'hideTitle': true, 'fontFamily': 'Microsoft YaHei',
        'fontSize': 4 }})

官方所有 打印示例

这些示例都没有拖拽功能

Hi Print 源码 地址

官网

// 下列方法都是没有拖拽设计页面的, 相当于代码模式, 使用代码设计页面
// 想要实现拖拽设计页面,请往下看 '自定义设计'

var hiprintTemplate = new this.$pluginName.PrintTemplate();

var panel = hiprintTemplate.addPrintPanel({ width: 100, height: 130, paperFooter: 340, paperHeader: 10 });
//文本
panel.addPrintText({ options: { width: 140, height: 15, top: 20, left: 20, title: 'hiprint插件手动添加text', textAlign: 'center' } });
//条形码
panel.addPrintText({ options: { width: 140, height: 35, top: 40, left: 20, title: '123456', textType: 'barcode' } });
//二维码
panel.addPrintText({ options: { width: 35, height: 35, top: 40, left: 165, title: '123456', textType: 'qrcode' } });
//长文本
panel.addPrintLongText({ options: { width: 180, height: 35, top: 90, left: 20, title: '长文本:hiprint是一个很好的webjs打印,浏览器在的地方他都可以运行' } });
//表格
panel.addPrintTable({ options: { width: 252, height: 35, top: 130, left: 20, content: $('#testTable').html() } });
//Html
panel.addPrintHtml({ options: { width: 140, height: 35, top: 180, left: 20, content:'' } });
//竖线//不设置宽度
panel.addPrintVline({ options: { height: 35, top: 230, left: 20 } });
//横线 //不设置高度
panel.addPrintHline({ options: { width: 140, top: 245, left: 120 } });
//矩形
panel.addPrintRect({ options: { width: 35, height: 35, top: 230, left: 60 } });

//打印
hiprintTemplate.print({});
//直接打印,需要安装客户端
hiprintTemplate.print2({});

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

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

相关文章

使用videjs+vue2+elementui自定义播放器控件

一、安装项目所需依赖 videojs依赖&#xff1a; npm install --save-dev video.js elementui依赖&#xff08;这个图方便就不按需引入了&#xff09;&#xff1a; npm i element-ui -S 二、main.js修改 增加以下几行&#xff1a; import videojs from video.js import e…

成功解决:下载的谷歌浏览器,打开却是“2345浏览器”,方法亲测有效

今天打开谷歌浏览器使用&#xff0c;浏览器界面显示的2345浏览器&#xff0c;难道谷歌把2345收购了&#xff1f;应该不能&#xff0c;上网查找问题原因才发现&#xff0c;原来的谷歌首页是被劫持了。&#xff08;如果迫切解决问题&#xff0c;直接拉到底找方法&#xff09; 试了…

前端必备的谷歌浏览器JSON可视化插件:JSON-Handle

功能简介: 日常开发过程中,对接后台返回的数据接口时,数据格式常常是各种json格式字符串,在netWork里面查看十分不便,需要在网上找一个json格式化的工具再查看,然后再取数据字段,然后绑定到页面上,十分不便,推荐这么一款前端开发的浏览器插件工具给大家使用。 返回数…

【React-Hooks进阶】useState回调函数的参数 / useEffect发送网络请求/ useRef / useContext

前言 博主主页&#x1f449;&#x1f3fb;蜡笔雏田学代码 专栏链接&#x1f449;&#x1f3fb;React专栏 上篇文章初步学习了Hooks的基础知识 今天来深入学习Hooks的一些扩展知识 感兴趣的小伙伴一起来看看吧~&#x1f91e; 文章目录useState -回调函数的参数使用场景语法语法规…

el-switch

目录 在element ui中el-switch开关组件具有先改变开关值再传值的特点。&#xff08;先改后传&#xff09; 1、触发change事件时 2、绑定disabled属性写三元表达式时 3、解决办法 在element ui中el-switch开关组件具有先改变开关值再传值的特点。&#xff08;先改后传&#xf…

cron表达式 详解

corn表达式是&#xff1a;由若干数字、空格、符号按一定的规则&#xff0c;组成的一组字符串&#xff0c;从而表达时间的信息。 好像和正则表达式有点类似哈&#xff0c;都是一个字符串表示一些信息。Cron 表达式生成器&#xff1a; https://www.smart-tools.cn/cron简介Cron 表…

基于Java+MySQL 实现(Web)日程管理系统【100010222】

基于Java的日程管理系统开发 摘要 日程管理在日常生活中是十分普通的一件事情&#xff0c;人们无论在生活中还是工作中都会有大大小小、各种各样的事情安排&#xff0c;如果仅仅靠纸张或者自己记录这些事情&#xff0c;往往会遗忘。针对这样的痛点&#xff0c;本文提供了日程…

HTML小图标的使用(无需下载图标源码)

我们在浏览一个网页中&#xff0c;会遇到很多有趣的小图标&#xff0c;这些小图标与访问者形成了友好的互动&#xff0c;所以我们在开发中都会适当插入一些生动有趣的图标来吸引访问者。插入图标的网站有很多&#xff0c;我这里以阿里巴巴图标库&#xff08;iconfont-阿里巴巴矢…

Div标签里放img和span标签实现垂直水平居中

正常默认布局 代码实现&#xff1a; <div style"width: 400px; height:400px; background-color:blueviolet"><img style"width: 80px; height: 80px;" src"./picture.png"><span style"color:white;">我是span标…

Vue3 使用MD5加密(清晰明了)

概述 最近在想做个cloud项目,gitee上找了个模板项目&#xff0c;前端使用到vue3 typeScript、Element Plus、Vue Router、Pinia、Axios、i18n、Vite等技术&#xff0c;最近使用到vue3 MD5加密&#xff0c;顺便学习一下&#xff0c;在此总结一下&#xff0c;若有不足之处&…

《EDA前端软件开发工程师面试指南》

2023届EDA领域校招总结&#xff0c;完结撒花&#xff01;&#xff01;&#xff01; 目录 前言 一、EDA公司介绍 二、项目面试 1.自我介绍 2.项目深入 3.专业经验 4.成果和技能 5.对面试官有什么问题 三、C面试 1、高频考点 2、其他知识点 3、算法题 四、逻辑综合面…

【前端代码实例】使用HTML5+CSS3+JavaScript制作一个响应式的后台管理系统~带侧边导航栏仪表盘功能

bilibili在线视频演示地址: 【前端代码实例】使用HTML5+CSS3+JavaScript制作一个响应式的后台管理系统~带侧边导航栏仪表盘功能 效果图: 完整代码: <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><meta…

前端已死?后端已亡?弯弯绕绕,几分真几分假

前段时间&#xff0c;我在掘金分享了一篇GPT-4 性能文章&#xff0c;也许是过于强大带来的威胁性&#xff0c;引来评论区的排队哀嚎&#xff08;如下图&#xff09;&#xff0c;所以“前端已死&#xff0c;后端已亡”这个概念真的成立吗&#xff1f;本文着重探讨前端。 前端和后…

Seurat | 强烈建议收藏的单细胞分析标准流程(基础质控与过滤)(一)

1. 写在前面 作为现在最火的scRNAseq分析包&#xff0c;Seurat当之无愧。&#x1f618; 本期开始我们介绍一下Seurat包的用法&#xff0c;先从基础质控和过滤开始吧。&#x1f973; 2.用到的包 rm(list ls()) library(Seurat) library(tidyverse) library(SingleR) library…

钉钉消息防撤回功能研究与实现-可查看历史消息[文件/图文/管理员/链接 撤回拦截]

研究背景 由于在某个大学进行上课的时候,遇到的某个老师,总是习惯发过的消息,到第二天的时候撤回,我们用聊天工具的其中一个原因,不就是因为可以随时去查看发过的消息吗&#xff0c;&#xff0c;而这位老师的操作,也让包括我在内的很多人感到痛不欲生。 想一想,当自己想要去看下…

Error in mounted hook: TypeError: Cannot read properties of undefined (reading isHiddenDay ) found

Error in mounted hook: TypeError: Cannot read properties of undefined (reading isHiddenDay ) found 无法读取未定义的属性‘isHiddenDay’. 在vue中使用fullcalendar在mounted钩子中渲染报错 背景 我在一个小demo中实现还是好好的&#xff0c;并且用的依赖都是6.x版本的…

初入了解——什么是VUE

个人简介&#xff1a;云计算网络运维专业人员&#xff0c;了解运维知识&#xff0c;掌握TCP/IP协议&#xff0c;每天分享网络运维知识与技能。座右铭&#xff1a;海不辞水&#xff0c;故能成其大&#xff1b;山不辞石&#xff0c;故能成其高。个人主页&#xff1a;小李会科技的…

vue3+ts项目里如何使用状态管理pinia以及数据持久化

我们都知道在vue2项目里搭配状态管理vuex3XX使用&#xff0c;效果极好的。 虽然在vue3项目里&#xff0c;vuex4XX仍能发挥余热&#xff0c;但由于缺乏对于ts的支持&#xff0c;使得类型推断陷入僵局。 所以在vue3ts的项目里&#xff0c;vuex渐被舍弃&#xff0c;pinia取而代之…

微信小程序入门教程 --(保姆级)

一、小程序注册 1、首先&#xff0c;到小程序官网注册自己的小程序账号&#xff0c;以下附有地址和教程&#xff1a; 小程序官网 进入这个地址之后&#xff0c;会看到这样的页面&#xff0c;点击立即注册按钮 2、在接下来的页面&#xff0c;选择小程序 3、然后根据提示完成三…

Web基础 HTML标签 六种超链接标签的使用方式

超链接标签&#xff08;重点&#xff09; 1、链接的语法格式&#xff1a; <a href"跳转目标链接" target"目标窗口的弹出方式"> 文本或图像 </a><a>标签里的a是单词anchor的的缩写&#xff0c;意为:锚。 两个属性的作用如下&#xff…