react18+ts如何生成二维码并且下载
目录
(图片来源网络,侵删)
一、下载qrcode.react
二、引入qrcode.react
三 、编写下载二维码的函数
在react开发中如果需要二维码,笔者选择使用qrcode.react来快速生成。
一、下载qrcode.react
pnpm add qrcode.react
二、引入qrcode.react
import {Box,Stack,Fab} from '@mui/material';
import { QRCodeCanvas } from 'qrcode.react';
import { useState} from "react";
export const Component = () => {
const currentUrl = window.location.protocol + '//' + window.location.host;
console.log('🚀 ~ file: Receive.tsx:33 ~ Component ~ currentUrl:', currentUrl);
const [qrValue, setQrValue] = useState(currentUrl);
return (
{
excavate: true,
src: '/logo-128.png',
width: 30,
height: 30
}}
/
);
};
Component.displayName = 'ReceivePage';
qrcode.react具体配置参数请参考官网qrcode.react
三 、编写下载二维码的函数
//base64转文件
const dataURLtoBlob = (dataurl: string) => {
const arr = dataurl.split(',') as any;
const mime = arr[0].match(/:(.*?);/)[1];
const bstr = atob(arr[1]);
let n = bstr.length;
const u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new Blob([u8arr], { type: mime });
};
//创建a标签用于下载
const downloadFile = (url: string, name: string) => {
const a = document.createElement('a');
a.setAttribute('href', url);
a.setAttribute('download', name);
a.setAttribute('target', '_blank');
a.dispatchEvent(new MouseEvent('click')); //模拟点击
/* const clickEvent = document.createEvent('MouseEvents');
clickEvent.initEvent('click', true, true); //模拟点击,initEvent(方法已经弃用)
a.dispatchEvent(clickEvent); */
};
//下载二维码
const handleDownLoadQRCode = () => {
//先获取要下载的二维码
const Qr = document.getElementById('qrCode') as any;
//把canvas的数据改成base64的格式
const canvasUrl = Qr!.toDataURL('image/png');
const myBlob = dataURLtoBlob(canvasUrl);
const myUrl = URL.createObjectURL(myBlob); // 创建blob下载地址
downloadFile(myUrl, 'qrCode');
};
最后附上完整代码:
import { Box, Stack, Fab } from '@mui/material';
import { QRCodeCanvas } from 'qrcode.react';
import { useState } from 'react';
export const Component = () => {
const currentUrl = window.location.protocol + '//' + window.location.host;
console.log('🚀 ~ file: Receive.tsx:33 ~ Component ~ currentUrl:', currentUrl);
const [qrValue, setQrValue] = useState(currentUrl);
//base64转文件
const dataURLtoBlob = (dataurl: string) => {
const arr = dataurl.split(',') as any;
const mime = arr[0].match(/:(.*?);/)[1];
const bstr = atob(arr[1]);
let n = bstr.length;
const u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new Blob([u8arr], { type: mime });
};
//创建a标签用于下载
const downloadFile = (url: string, name: string) => {
const a = document.createElement('a');
a.setAttribute('href', url);
a.setAttribute('download', name);
a.setAttribute('target', '_blank');
a.dispatchEvent(new MouseEvent('click')); //模拟点击
/* const clickEvent = document.createEvent('MouseEvents');
clickEvent.initEvent('click', true, true); //模拟点击,initEvent(方法已经弃用)
a.dispatchEvent(clickEvent); */
};
//下载二维码
const handleDownLoadQRCode = () => {
//先获取要下载的二维码
const Qr = document.getElementById('qrCode') as any;
//把canvas的数据改成base64的格式
const canvasUrl = Qr!.toDataURL('image/png');
const myBlob = dataURLtoBlob(canvasUrl);
const myUrl = URL.createObjectURL(myBlob); // 创建blob下载地址
downloadFile(myUrl, 'qrCode');
};
return (
{
excavate: true,
src: '/logo-128.png',
width: 30,
height: 30
}}
/
点击下载二维码
);
};
Component.displayName = 'ReceivePage';
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
