qrcode.react生成二维码,
qrcode.react - npm很简单,安装依赖包,然后引用就行了
npm install qrcode.react
或者
yarn add qrcode.react
直接上写好的代码
- import React, {useEffect, useState} from 'react';
- import QRCode from 'qrcode.react'
-
-
- /**
- * 二维码组件,使用memo函数包裹减少渲染,优化性能
- * @since 20231107
- * @author QC班长
- */
- export type QRCodeImageProps = {
- url: string,//需要转为二维码的h5链接
- size?: number,//二维码的大小 单位px,不传默认138px
- fgColor?: string,//二维码的颜色 不传默认黑色
- }
- export default React.memo(function QRCodeImage({url, size, fgColor}: QRCodeImageProps) {
-
- //随机数id
- const [randomId, setRandomId] = useState<string>('')
- //生成的二维码图片链接
- const [qrcodeUrl, setQrcodeUrl] = useState<string>('')
-
- //生成随机数id
- const uuid = () => {
- return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {
- const r:number = (Math.random() * 16) | 0
- const v:number = c === 'x' ? r : (r & 0x3) | 0x8
- return v.toString(16)
- })
- }
-
- useEffect(() => {
- setRandomId(uuid())
- }, [])
-
- useEffect(() => {
- //获取canvas类型的二维码
- const canvasImg = document.getElementById(randomId) as HTMLCanvasElement
- //将canvas对象转换为图片的data url
- setQrcodeUrl(canvasImg?.toDataURL('image/png'))
- }, [randomId, size])
-
- return (
- <>
- <div style={{position: 'absolute', opacity: '0', zIndex: '-100'}}>
- {url && randomId && (
- <QRCode
- id={randomId}
- value={url}
- size={size ?? 138} // 二维码的大小
- fgColor={fgColor ?? '#000000'} // 二维码的颜色
- style={{margin: 'auto', backgroundColor: 'white', padding: '10px'}}/>
- )}
- div>
- <img src={qrcodeUrl} alt={url}/>
- >
- )
-
- })
使用传入URL就行,size可自己定
1. 首先,需要确定当前屏幕的像素密度(pixel density)。常见的像素密度是每英寸像素数(PPI)为 96。可以根据实际情况进行调整。
2. 然后,可以使用以下公式将毫米转换为像素:
像素 = 毫米 * (像素密度 / 25.4)
例如,如果想将 10 毫米转换为像素,且像素密度为 96 PPI,那么计算方式如下:
像素 = 10 * (96 / 25.4) ≈ 37.7952755906 px
所以,在代码中将毫米转换为像素,可以使用上述公式进行计算。将这个转换过程封装成一个过滤器或者自定义方法,以便在模板中直接调用和使用。
参考文献: