vue中生成条形码(jsbarcode)、二维码(qrcodejs2)

本文介绍如何使用jsbarcode和qrcodejs2插件分别生成条形码和二维码,并解决了在打印过程中重复生成二维码的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.条形码插件jsbarcode

安装:npm install jsbarcode --save

引入:在需要生成条形码的页面引入即可

import JsBarcode from 'jsbarcode'

需要显示条形码的页面里

<img id="barcode1">

调用构造函数生成条形码

let barCode1 = this.info.marIdCode;
let barheight = this.imgHeight;
JsBarcode("#barcode1",barCode1,{
    format:"CODE128",//条形码的格式
    width:1,//线宽
    height:barheight,//条码高度
    lineColor:"#000",//线条颜色
    displayValue:false,//是否显示文字
    margin:2//设置条形码周围的空白区域
})

2.二维码插件

安装:npm install qrcodejs2 --save

引入:同理,在需要生成二维码的页面中引入即可

import QRCode from 'qrcodejs2'

需要显示二维码的页面中

<div id="SetQRCode"></div>

根据自身需求逻辑使用

let qrCode = "#"+this.info.marId+"#"+this.info.supManufacturingBatch+"#"+this.info.exp+"#"+this.info.minflowId+"#"+this.info.num;
this.QRCode = qrCode;
let qrcodeDiv = document.getElementById("SetQRCode")
let qrcode = new QRCode(qrcodeDiv,{
    text:this.QRCode,//二维码中的内容
    width:this.QRWidth,
    height:this.QRHeight,
    colorDark:"#000",//二维码颜色
    correctLevel: QRCode.CorrectLevel.L //容错率,L/M/H
})
this.qrcode = qrcode;

好啦,如果只需要将二维码展示出来,不需要点击按钮才生成二维码或不需要打印的小伙伴看到这里就行啦~

打印!!!

在写二维码打印的时候我真的栓q住了,呜呜呜~ 因为进入打印页面后,点击取消,再次点击打印我惊讶地发现给我生成了两个二维码,然后……嗯,没错,重复上述操作会一直新生成二维码。

因此需要删除之前生成的二维码。代码如下:

let qrCode = "#"+this.info.marId+"#"+this.info.supManufacturingBatch+"#"+this.info.exp+"#"+this.info.minflowId+"#"+this.info.num;
this.QRCode = qrCode;
let qrcodeDiv = document.getElementById("SetQRCode")
let qrcode = new QRCode(qrcodeDiv,{
    text:this.QRCode,
    width:this.QRWidth,
    height:this.QRHeight,
    colorDark:"#000",
    correctLevel: QRCode.CorrectLevel.L
    }
this.qrcode = qrcode;
// ………………………………………………………………(解决重复点击打印按钮会重复一直生成二维码)
let childs = document.getElementById("SetQRCode").childNodes;
for(let i = childs.length -2 ; i>=0 ; i--){
    document.getElementById("SetQRCode").removeChild(childs[i]);
}

### 在 Vue 中使用 qrcodejs2 实现条形码功能 虽然 `qrcodejs2` 主要用于生成二维码,但可以借助类似的逻辑来实现条形码的功能。然而,对于条形码来说,通常会使用专门的库如 `JsBarcode` 来完成这一任务[^3]。 #### 安装依赖包 为了在 Vue 项目中集成条形码生成功能,首先需要安装必要的 npm 包: ```bash npm install jsbarcode --save ``` #### 创建组件结构 接着,在模板部分定义好放置条形码的位置,通过 `<svg>` 或者其他 HTML 元素作为容器: ```html <template> <div class="barcode-container"> <!-- 这里设置了一个 SVG 元素用来承载最终渲染出来的条形码 --> <svg id="barcode"></svg> </div> </template> ``` #### 编写脚本代码 随后,在 `<script setup>` 部分引入所需的模块并编写初始化函数以调用 `JsBarcode` 方法绘制条形码图像: ```javascript <script setup> import { onMounted } from 'vue'; import JsBarcode from 'jsbarcode'; onMounted(() => { // 调用 JsBarcode 函数传入目标 DOM 和想要编码的数据字符串以及样式配置对象 JsBarcode('#barcode', '这里是你要编码的信息', { format: "CODE128", // 可选参数指定使用的条形码标准 lineColor: "#000", width: 2, height: 80, displayValue: true, // 是否显示底部的文字说明,默认为true }); }); </script> ``` 以上就是在 Vue 应用程序内部集成了条形码生成器的一个简单例子。值得注意的是,尽管这里展示的方法是针对条形码的具体操作,但是其基本思路同样适用于处理二维码的情况——即加载相应的 JavaScript 类库之后按照官方文档指导进行 API 的调用即可。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值