使用 Vue3 生成二维码和条形码

news2025/1/12 4:08:56

目录

前言

一、前期准备

1.1. 使用Vite创建工程化项目

1.2 安装所需的依赖

 二、环境检查

三、生成二维码

3.1 创建二维码组件

3.2 在App.vue中使用二维码组件

四、生成条形码

4.1 创建条形码组件

4.2.在App.vue中使用条形码组件

五、启动测试与效果演示

5.1 启动demo

5.2 二维码演示

5.3 条形码演示


前言

        在我刚接触CSDN时,便写下了第一篇使用python库生成二维码的博文,但是随着学习的知识越来越多,实现同一个功能,但可以通过不同的方式得以实现,本篇是通过Vue3和Vue的一些组件库从而实现的一个小demo

前期准备

1.1. 使用Vite创建工程化项目

        这里可以在vscode或是其他的IDE,或是直接找一个合适的目录,然后在cmd中即可

npm create vite@latest

        输入要创建的vue项目名,然后回车,选择Vue,然后回车,这里我的项目名是demo0-happy

选择自己想用的,不知道直接选js

 进入文件所处的目录

cd demo0-happy

1.2 安装所需的依赖

首先输入npm i 也就是(npm install的缩写)

将使用qrcode库来生成二维码,使用bwip-js来生成条形码。可以通过以下命令安装它们:

npm install qrcode bwip-js

 二环境检查

        首先,请确保已经安装了Node.js和Vue CLI。如果还未安装,可以通过以下命令进行安装:

npm install @vue/cli

三、生成二维码

3.1 创建二维码组件

        在src/components目录下创建QRCodeGenerator.vue文件,并添加以下代码:

<script setup>
import { ref } from 'vue';
import QRCode from 'qrcode';

const text = ref('');
const qrCodeUrl = ref("");

async function generateQRCode() {
  try {
    qrCodeUrl.value = await QRCode.toDataURL(text.value);
  } catch (err) {
    console.error(err);
  }
}

</script>

<template>
  <div>
      <h2>二维码生成器</h2>
      <input v-model="text" placeholder="输入文本生成二维码">
      <button @click="generateQRCode">生成二维码</button>
      <div v-if="qrCodeUrl">
        <img :src="qrCodeUrl" alt="二维码"/>
      </div>
    </div>
</template>

<style scoped>

</style>

3.2 在App.vue中使用二维码组件

        打开src/App.vue文件,导入并使用QRCodeGenerator组件:

<script setup>
import QRCodeGenerator from './components/QRCodeGenerator.vue'
</script>

<template>
  <div>
    <QRCodeGenerator></QRCodeGenerator>
    <hr>
  </div>
</template>

<style scoped>
</style>

四、生成条形码

4.1 创建条形码组件

在src/components目录下创建BarcodeGenerator.vue文件,并添加以下代码:

<script setup>
import bwipjs from 'bwip-js'
import { ref } from 'vue'

const text = ref('')
const barcodeCanvasRef = ref("")

function generateBarcode() {
  bwipjs.toCanvas(barcodeCanvasRef.value, {
    bcid: 'code128', // 条形码类型
    text: text.value,
    scale: 3, // 缩放比例
    height: 10, // 条形码高度
    includetext: true, // 是否包括文本
    textxalign: 'center' // 文本对齐方式
    
  })
}
</script>

<template>
  <div>
    <h2>条形码生成器</h2>
    <input v-model="text" placeholder="输入文本生成条形码" aria-label="输入文本" />
    <button @click="generateBarcode" aria-label="生成条形码">生成条形码</button>
    <canvas ref="barcodeCanvasRef"></canvas>
  </div>
</template>

<style scoped>

</style>

4.2.在App.vue中使用条形码组件

        同样,在src/App.vue中导入并使用BarcodeGenerator组件,此时会将之前的二维码的一并导入:

<script setup>
import QRCodeGenerator from './components/QRCodeGenerator.vue'
import BarcodeGenerator from './components/BarcodeGenerator.vue'

</script>

<template>
  <div>
    <QRCodeGenerator></QRCodeGenerator>
    <hr>
    <BarcodeGenerator></BarcodeGenerator>
  </div>
</template>

<style scoped>
</style>

启动测试与效果演示

5.1 启动demo

切换到项目的目录下,在项目的目录下启动

npm run dev 

将出现的url链接打开,便会出现下面的界面

 

5.2 二维码演示

        输入想要生成二维码的文字和信息,或是链接,然后点击生成二维码按钮即可,这里使用了utools的二维码识别截图工具(QRscan)识别如下

 

5.3 条形码演示

        这里操作的方式和上面是一样的

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

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

相关文章

【前端可视化】大屏可视化项目三 包含了横向柱形图、竖向柱形图、雷达图、环形图、关系图、数据云图、数据展示图和地图可视化等八个部分

基于vite与tailwindcss创建大屏可视化 项目准备 传统的三列布局 <template><div class"w-full h-full"><div v-if"loading" class"bg-[url(assets/images/bg.png)] bg-cover bg-center loading-container h-screen w-full flex jus…

Arthas简介及示例

一、什么是Arthas&#xff1f; Arthas 是一款线上监控诊断产品&#xff0c;通过全局视角实时查看应用 load、内存、gc、线程的状态信息&#xff0c;并能在不修改应用代码的情况下&#xff0c;对业务问题进行诊断&#xff0c;包括查看方法调用的出入参、异常&#xff0c;监测方…

记2024-08原生微信小程序开发

继2024.08 最近需要开发一个微信小程序的一个功能模块&#xff0c;但是之前在学的时候都是好几年前的东东了&#xff0c;然后重新快速过了一遍b站大学的教程&#xff0c;这篇文章就是基于教程进行的一些总结&#xff0c;和自己开发过程当中使用到的一些点和一些技巧什么的吧。 …

uniapp小程序出现【 wxss GetCompiledResult】报错

报错信息 进入页面报错&#xff0c;导致页面无法显示 原因 查看小程序源代码发现 wxss 文件内有个不正常的字符 就是这个 * 导致解析失败 出现解析失败的原因 / 解决办法 是因为这里使用了通配符 注释掉就可以了

多组织系统的设计思路

一、什么是多组织系统 多组织这个概念是一般多用于企业信息化系统。通常是指一个集团分拆了多个子公司进行运营&#xff0c;每家子公司负责集团业务的一个到多个部分&#xff0c;多家子公司共同支撑集团的全部业务。 子公司内部&#xff0c;在业务执行过程中相对独立&#xf…

c++标准库STL————string类的基础模拟

string类 一、构造类函数1.构造一个空内容的对象2.用已知对象进行拷贝构造3.用c语言字符串的形式构造 二、容量型函数三、对象访问四、修改类操作4、非成员函数 一、构造类函数 c11提供了许多参数的重组&#xff0c;但通常这四种类型的构造较为常用。 1.构造一个空内容的对象 …

Python 机器学习求解 PDE 学习项目 基础知识(4)PyTorch 库函数使用详细案例

PyTorch 库函数使用详细案例 前言 在深度学习中&#xff0c;PyTorch 是一个广泛使用的开源机器学习库。它提供了强大的功能&#xff0c;用于构建、训练和评估深度学习模型。本文档将详细介绍如何使用以下 PyTorch 相关库函数&#xff0c;并提供相应的案例示例&#xff1a; to…

我在高职教STM32——I2C通信之读写EEPROM(1)

大家好,我是老耿,高职青椒一枚,一直从事单片机、嵌入式、物联网等课程的教学。对于高职的学生层次,同行应该都懂的,老师在课堂上教学几乎是没什么成就感的。正是如此,才有了借助CSDN平台寻求认同感和成就感的想法。在这里,我准备陆续把自己花了很多心思设计的教学课件分…

日撸Java三百行(day18:循环队列)

目录 一、顺序队列与循环队列 二、代码实现 1.循环队列创建 2.循环队列遍历 3.循环队列入队 4.循环队列出队 5.数据测试 6.完整的程序代码 总结 一、顺序队列与循环队列 在昨天&#xff0c;我们提到队列实现除了采用链式存储结构&#xff0c;还可以采用顺序存储结构&…

数字电路波形图绘制工具WaveDrom简介

最近写东西的时候&#xff0c;需要画波形图&#xff0c;无意中找到了一蛮好用的工具&#xff1a;WaveDrom WaveDrom 是一个 JavaScript 应用程序。WaveJSON 是一种描述数字时序图的格式。WaveDrom 直接在浏览器内部渲染这些时序图。元素 “signal” 是一个 WaveLane 数组。每个…

NO.4 软件外包公司

今天我们来聊聊国内的四大软件外包公司。这些公司不仅在国内市场中占据重要地位&#xff0c;还对全球软件外包行业产生了影响。 部分数据来源网络排名&#xff0c;按照职位量、增长速度排名&#xff0c;排名仅供参考&#xff0c;去某家公司一定要多方位参考&#xff0c;比如企查…

uniapp基础知识【搬代码】

基础知识 HTML、css、javaScript&#xff08;ES6&#xff09; HTML结构 1.View 类似于传统html中的div&#xff0c;用于包裹各种元素内容。 2.text文本 3.swoper 4.image 5.video 6.button 7.input <template><!-- <view class"content"><imag…

泛微E-office 10 schema_mysql接口敏感信息泄露漏洞复现 [附POC]

文章目录 泛微E-office 10 schema_mysql接口敏感信息泄露漏洞复现 [附POC]0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现泛微E-office 10 schema_mysql接口敏感信息泄露漏洞复现 [附POC] 0x01 前言 免责声明:请勿利用文章内…

两篇论文同时获最佳论文荣誉提名,SIGGRAPH上首个Real-Time Live的中国团队用生成式AI创建3D世界

专注于计算机图形学的全球学术顶会 SIGGRAPH&#xff0c;正在出现新的趋势。 点击访问我的技术博客https://ai.weoknow.comhttps://ai.weoknow.com 在上周举行的 SIGGRAPH 2024 大会上&#xff0c;最佳论文等奖项中&#xff0c;来自上海科技大学 MARS 实验室的团队同时拿到两篇…

HTML表单元素

HTML表单元素 表单把用户的信息发给服务器。 <!DOCTYPE html> <html><head><meta charset"utf-8"><title></title> </head><body><form class"stylin_form1" action"process_form.php" met…

uni-app开发微信小程序注意事项,不要用element-ui

前端扩展组件千万不要用element-ui&#xff0c;开发的时候不报错&#xff0c;发布的时候会报错无法发布。 可以用vant weapp【注意是weapp】 iView weapp 附上hbuilder官方文档 组件的概念 | uni-app官网 (dcloud.net.cn)

git-贮藏区打补丁

1.显示所有贮藏 git stash list 2.将贮藏区的修改打补丁 git stash show -p stash{0} > patchName.patch commit打补丁 git 生成补丁文件及打补丁_git 生成指定目录补丁-CSDN博客 git patch的使用方法_git pattch-CSDN博客

「MyBatis」数据库相关操作

MyBatis 简介 MyBatis 是⼀个持久层框架&#xff0c;用于简化 JDBC 的开发 持久层指的就是持久化操作的层&#xff0c;通常指数据访问层 (dao)&#xff0c;是用来操作数据库的 Mapper 注解的接口表示该接口是 MyBatis 中的 Mapper 接口 回顾一下之前提到过的图 简单来说&…

如何选用合适的开源知识管理系统?10款软件推荐

国内外主流的10款开源知识管理软件对比&#xff1a;PingCode、Worktile、DokuWiki、MediaWiki、GitBook、Nuclino、Think、TiddlyWiki、AFFiNE、Foam。 在管理知识的广阔天地中&#xff0c;选择合适的工具可能会让你感到头痛。开源知识管理软件以其灵活性和成本效益在行业内脱颖…

Java设计模式-单例模式最佳实践

1. 单例模式简介 Java 单例模式是四大设计模式之一&#xff0c;属于创建型设计模式。从定义上看&#xff0c;它似乎是一种简单的设计模式&#xff0c;但在实现时&#xff0c;如若不注意&#xff0c;它会带来很多问题。 在本文中&#xff0c;我们将了解单例设计模式原则&#…