react18+ts如何生成二维码并且下载

2024-05-14 1259阅读

目录

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';
VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]