react本身有一些打印的组件,但都不好用,都是基于window.print()
,window.print()
直接打印的话,处理直接当前网页的body设置为你要打印的区域,但是当你取消打印的时候你会发现整个网页都被你要打印的区域占满了,你还得用window.reload()重新加载一下页面,用户交互很不好,建议不要采用这种方式。
QRCode.js 生成二维码
QRCode.js 是一个用于生成二维码图片的插件。
使用方法
载入 JavaScript 文件
1 | <script src="qrcode.js"></script> |
DOM 结构
1 | <div id="qrcode"></div> |
调用
1 | // 简单方式 |
Ant Design里使用
react中一般生成二维码都是用react.qrcode,但是发现这玩意生成的是canvas,不是图片,打印的时候预览不出来。所以我想进一切办法去把canvas转成图片,无奈拿不到这个canvas标签。最后还是用js的qrcode来生成二维码,这样生成的默认是base64位的图片,打印正常。代码如下:
安装
cnpm install qrcode --save
在页面上引入
1 |
|