vue 中生成二维码、条形码

本文介绍了在Vue项目中如何生成条形码和二维码。通过引入jsbarcode库来生成条形码,详细步骤包括npm安装、组件引入及模板使用。对于二维码的生成,文章推荐了qrcode插件,同样包含npm安装和模板使用方法。

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

在 vue 项目中难免遇到有要生成条形码 或者 二维码的功能需求。

一、生成条形码  

1、下载 npm install jsbarcode --save  

2、在所需组件模块中引入 

 import JsBarcode from 'jsbarcode' 

3、template 中

 <svg id="barcode"></svg>

4、

 barcode(){
        let barCode = "12345678"
        JsBarcode("#barcode", "Hi world!",{
          format: "CODE128",//选择要使用的条形码类型
          text: barCode,    //显示文本
          displayValue: true,//是否在条形码下方显示文字
          textPosition: "bottom"//设置文本的垂直位置
          fontOptions:"bold italic",//使文字加粗体或变斜体
          background:"#eee",//设置条形码的背景
          font:"fantasy",//设置文本的字体
          lineColor:"#2196f3",//设置条和文本的颜色。
          margin:15//设置条形码周围的空白边距
        })
      },

以上步骤就可以生成一个条形码 至于何时调用 barcode 这个方法就看我们自己啦!

有许多参数也给大家写了出来, 大家自行选自所需参数哈!

 </

### 使用 Vue 生成二维码条形码并实现下载 #### 插件介绍 为了在 Vue 项目中轻松创建二维码条形码,可以使用 `qrcode` 和 `jsbarcode` 这两个 JavaScript 库。这些库提供了简单易用的方法来生成所需的编码。 对于二维码生成,推荐使用 `qrcode` 库[^1]。该库允许通过简单的 API 调用来创建自定义样式丰富的 QR Code 图像文件。而对于条形码,则可以选择 `JsBarcode` 库[^2],它支持多种类型的线性条形码格式,并且同样易于集成到前端应用当中。 #### 安装依赖项 首先,在命令行终端执行以下 npm 命令安装必要的包: ```bash npm install qrcode jsbarcode ``` #### 组件开发 接下来展示如何构建一个基本组件用于显示以及导出这两种形式的数据表示方式。 ##### HTML 结构 (template) ```html <template> <div class="code-generator"> <!-- 输入框 --> <input v-model="textToEncode" placeholder="Enter text or URL..." /> <!-- 切换按钮 --> <button @click="toggleType">Switch to {{ currentType === 'QR' ? 'Bar' : 'QR' }} code</button> <!-- 显示区域 --> <canvas id="qrCanvas"></canvas> <svg id="barSvg"></svg> <!-- 下载链接 --> <a :href="downloadLink" download="generated-code.png"><button>Download Image</button></a> </div> </template> ``` ##### Script 部分 ```javascript <script setup> import { ref, computed } from "vue"; import * as QRCode from "qrcode"; import JsBarcode from "jsbarcode"; // 数据绑定变量初始化 const textToEncode = ref(""); const currentType = ref('QR'); function toggleType() { currentType.value = currentType.value === 'QR' ? 'Bar' : 'QR'; } // 计算属性:动态设置 canvas 或 svg 的可见状态 const displayElementId = computed(() => `${currentType.value.toLowerCase()}${currentType.value === 'QR' ? 'Canvas' : 'Svg'}`); // 方法:更新画布上的内容 async function updateDisplayContent() { const element = document.getElementById(displayElementId.value); if (!element || !textToEncode.value.trim()) return; try { switch(currentType.value){ case 'QR': await QRCode.toCanvas(element, textToEncode.value); break; default: JsBarcode(element).clear().barcodes(textToEncode.value); } } catch(error) { console.error("Failed to generate the requested type of code.", error); } } watch([textToEncode,currentType],updateDisplayContent); // 导出图像链接计算属性 const downloadLink = computed(() => { let elem = document.querySelector(`#${displayElementId.value}`); if(!elem)return "#"; var dataURL; if(elem.tagName=="CANVAS"){ dataURL=elem.toDataURL(); }else{ var svgData= new XMLSerializer().serializeToString(elem); dataURL=`data:image/svg+xml;base64,${btoa(svgData)}` } return dataURL.replace("image/png", "image/octet-stream"); }); </script> ``` 此代码片段展示了如何在一个 Vue 单文件组件内完成从用户输入转换成可视化的二维/一维编码的过程,并提供了一个可点击的下载按钮让用户保存生成的结果作为图片文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值