vue-qr生成的二维码增加下载功能

大家好!今天给大家分享一个超实用的前端小技巧——如何在 Vue 项目中生成二维码并实现下载功能。这个功能在分享链接、活动推广等场景特别有用,一起来学习吧!
🔍 功能预览

  • 使用 vue-qr 生成美观二维码
  • 点击按钮即可下载 PNG 格式的二维码
  • 兼容现代浏览器,响应式设计
    🛠️ 所需依赖
    首先确保安装这两个关键库:
npm install vue-qr file-saver --save
# 或
yarn add vue-qr file-saver

核心代码实现

  1. 组件引入
import VueQr from 'vue-qr';
import { saveAs } from 'file-saver'; // 文件下载神器
  1. 模板部分 - 二维码展示区
<template><div class="qr-container"><!-- 二维码生成组件 --><vue-qr:text="qrContent":size="200":margin="10":callback="getCodeUrl"></vue-qr><!-- 下载按钮 --><button @click="downloadQr" class="download-btn">下载二维码</button></div>
</template>
  1. 脚本部分 - 核心逻辑
<script>
export default {data() {return {qrContent: 'https://example.com', // 默认二维码内容qrBlob: null,    // 存储二维码二进制数据fileName: '我的二维码.png' // 默认文件名}},methods: {// 二维码生成回调getCodeUrl(dataURL) {// 移除Base64前缀const base64Data = dataURL.replace(/^data:image\/\w+;base64,/, '');// 转换Base64为二进制数据const byteArray = Uint8Array.from(atob(base64Data), c => c.charCodeAt(0));// 创建Blob对象this.qrBlob = new Blob([byteArray], { type: 'image/png' });},// 下载二维码downloadQr() {if (!this.qrBlob) {alert('请先生成二维码!');return;}// 使用file-saver保存文件saveAs(this.qrBlob, this.fileName);// 可以添加下载统计等扩展功能this.trackDownload();},// 扩展:下载统计trackDownload() {console.log('二维码下载次数+1');// 这里可以接入埋点统计}}
}
</script>

🚨 常见问题解决
Q1:为什么下载的文件损坏?
A:确保正确处理了Base64数据转换,特别注意替换前缀的正则表达式要准确。

Q2:如何在移动端兼容?
A:file-saver 在移动端可能有兼容性问题,可以添加提示:

downloadQr() {if (/Android|iPhone/i.test(navigator.userAgent)) {alert('长按图片即可保存到相册');return;}// ...原有下载逻辑
}

Q3:如何提高生成速度?
A:对于大量二维码生成,可以考虑使用Web Worker进行异步处理。
Q4:对于下载的图片有尺寸要求怎么办?
A:修改getCodeUrl,使用canvas转blob

    getCodeUrl(url, id) {const canvas = document.createElement("canvas");const img = new Image();img.src = url;img.onload = () => {canvas.width = 800;canvas.height = 800;const ctx = canvas.getContext("2d");ctx.drawImage(img, 0, 0, 800, 800);canvas.toBlob((blob) => {this.codeBlob = blob;}, "image/png");};},

如果有任何问题,欢迎在评论区留言讨论~ 😊

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

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

相关文章

嵌入式C进阶路线指南

嵌入式是工科&#xff0c;工科讲究实践。说的再多、懂得再多&#xff0c;不能做出实际的东西&#xff0c;是没有意义的。学习嵌入式的核心原则之一就是多动手写代码。另外还有一个原则就是&#xff1a;从浅到深学习。接下来的内容将贯彻这两个原则。最后强调一点&#xff0c;各…

服务器上机用到的设备

服务器上机通常需要以下硬件设备&#xff1a; 服务器主机&#xff1a; CPU&#xff1a;选择高性能的多核处理器&#xff0c;如英特尔至强&#xff08;Xeon&#xff09;系列或AMD EPYC系列&#xff0c;以满足高并发和多任务处理需求。 内存&#xff08;RAM&#xff09;&#xf…

FreeCAD傻瓜教程-涡轮蜗杆的快速绘制FCGear工作台的使用方法

起因&#xff1a;涡轮蜗轴的组合&#xff0c;是一种比较简单且高效的传动结构。可以实现减速、加速、转动角度的放大、缩小等应用。 如何绘制呢&#xff1f;我搜索了不少教程&#xff0c;看起来都挺复杂的&#xff0c;对于小白来说有点像天书。这里介绍和记录一下利用FreeCAD 的…

daplink开发_一次开发DAPLink的详细开发流程及调试步骤

以下是针对第一次开发DAPLink的详细开发流程及调试步骤,结合STM32平台特性,分阶段指导您完成从零到一的完整开发过程: 一、开发流程1. 硬件准备阶段选型STM32芯片:推荐型号:STM32F103C8T6(成本低、资源足够)、STM32F405RGT6(性能更强,支持更多外设)。关键外设需求:U…

给小白的AI Agent 基本技术点分析与讲解

引言&#xff1a;重塑交互与自动化边界的 AI Agent 在人工智能技术飞速发展的浪潮中&#xff0c;AI Agent&#xff08;智能体&#xff09;概念的兴起标志着自动化和人机交互正迈向一个全新的阶段。传统的软件系统通常被设计来执行精确预设的指令序列&#xff0c;它们强大且高效…

Mysql常用语句汇总

Mysql语句分类 DDL: 数据定义语言&#xff0c;用来定义数据库对象&#xff08;数据库、表、字段&#xff09;DML: 数据操作语言&#xff0c;用来对数据库表中的数据进行增删改DQL: 数据查询语言&#xff0c;用来查询数据库中表的记录DCL: 数据控制语言&#xff0c;用来创建数据…

【Python 模块】

Python 中的模块&#xff08;Module&#xff09;是组织代码的核心方式&#xff0c;通过将相关函数、类和变量封装到独立文件中&#xff0c;实现代码复用和结构化管理。以下是模块的核心知识点&#xff1a; 一、基础概念 1. 模块定义 任何 .py 文件都是一个模块模块名即文件名…

黑电平校正(Black Level Correction, BLC)算法

黑电平校正&#xff08;Black Level Correction, BLC&#xff09;算法 黑电平校正&#xff08;BLC&#xff09;是图像传感器&#xff08;如CMOS/CCD&#xff09;信号处理中的一个重要步骤&#xff0c;主要用于消除传感器暗电流&#xff08;Dark Current&#xff09;导致的基线…

处理PostgreSQL数据库事务死锁过程

查询pg_locks表&#xff0c;获取未得到满足的锁信息&#xff1a; select * from pg_locks where granted is false ; --查询得不到锁的&#xff0c;那就是两个互相等待对方持有的锁查询活动的事务会话进程&#xff0c;和上一步的锁的事务对应起来&#xff1a; select * from …

Android开发-文本显示

在Android应用开发中&#xff0c;文本显示是用户界面设计中最基本也是最重要的部分之一。无论是展示欢迎信息、错误提示还是动态内容&#xff0c;合理地使用文本元素能够极大地提升用户体验。本文将详细介绍如何在Android应用中有效地显示文本&#xff0c;包括使用TextView组件…

基于大模型的输卵管妊娠全流程预测与治疗方案研究报告

一、引言 1.1 研究背景与意义 输卵管妊娠作为异位妊娠中最为常见的类型,严重威胁着女性的生殖健康和生命安全。受精卵在输卵管内着床发育,随着胚胎的生长,输卵管无法提供足够的空间和营养支持,极易引发输卵管破裂、大出血等严重并发症,若救治不及时,甚至会导致孕产妇死…

当向量数据库与云计算相遇:AI应用全面提速

如果将AI比作一台高速运转的机器引擎&#xff0c;那么数据便是它的燃料。 然而&#xff0c;存储数据的燃料库--传统数据库&#xff0c;在AI时代的效率瓶颈愈发明显&#xff0c;已经无法满足AI对于数据的全新需求。 因此&#xff0c;向量数据库近年来迅速崛起。向量数据库通过…

Media3 中 Window 的时间相关属性详解

AndroidX Media3 的 Timeline.Window 类中&#xff0c;与时间相关的属性描述了媒体播放窗口&#xff08;window&#xff09;在时间维度上的关键信息。这些属性帮助开发者理解媒体的播放范围、起始点、持续时间以及与设备时间或直播流的同步关系。 Timeline.Window 的时间相关属…

【Python爬虫电商数据采集+数据分析】采集电商平台数据信息,并做可视化演示

前言 随着电商平台的兴起&#xff0c;越来越多的人开始在网上购物。而对于电商平台来说&#xff0c;商品信息、价格、评论等数据是非常重要的。因此&#xff0c;抓取电商平台的商品信息、价格、评论等数据成为了一项非常有价值的工作。本文将介绍如何使用Python编写爬虫程序&a…

工业相机的芯片CRA角度与镜头选型的匹配关系

工业相机的芯片CRA角度与镜头选型的匹配关系 Baumer工业相机​工业相机的芯片CRA角度的技术背景​工业相机的芯片CRA的信息CRA相差过大的具体表现怎样选择工业相机sensor的CRABaumer工业相机sensor的CRA工业相机的芯片CRA角度与镜头匹配好的优点 Baumer工业相机 工业相机是常用…

深度学习中常见的矩阵变换函数汇总(持续更新...)

1. 转置操作 (Transpose) 概念&#xff1a;将矩阵的行和列互换应用场景&#xff1a; 在卷积神经网络中转换特征图维度矩阵乘法运算前的维度调整数据预处理过程中的特征重排 原始矩阵 A [[1, 2, 3], 转置后 A^T [[1, 4],[4, 5, 6]] [2, 5],[3, 6]]代码…

day 14 SHAP可视化

一、原理——合作博弈论 SHAP&#xff08;SHapley Additive exPlanations&#xff09;是一种用于解释机器学习模型预测结果的方法&#xff0c;它基于合作博弈论中的 Shapley 值概念。Shapley 值最初用于解决合作博弈中的利益分配问题。假设有 n 个参与者共同合作完成一项任务并…

从0开始学习大模型--Day03--Agent规划与记忆

规划&#xff08;planning&#xff09; 规划&#xff0c;可以为理解观察和思考。如果用人类来类比&#xff0c;当我们接到一个任务&#xff0c;我们的思维模式可能会像下面这样: 1、首先会思考怎么完成这个任务。 2、然后会审视手头上所拥有的工具&#xff0c;以及如何使用这…

使用 Couchbase Analytics Service 的典型步骤

下面是使用 Couchbase Analytics Service 的典型步骤&#xff0c;包括部署、配置、创建数据集、运行查询以及监控优化等环节。 首先&#xff0c;您需要安装并启用 Analytics 服务&#xff1b;然后将节点加入集群并重平衡&#xff1b;接着在 Analytics 中映射数据服务的集合&am…

从零开始学习人工智能(Python高级教程)Day6-Python3 正则表达式

一、Python3 正则表达式 正则表达式是一个特殊的字符序列&#xff0c;它能帮助你方便的检查一个字符串是否与某种模式匹配。 在 Python 中&#xff0c;使用 re 模块来处理正则表达式。 re 模块提供了一组函数&#xff0c;允许你在字符串中进行模式匹配、搜索和替换操作。 r…