原生小程序生成二维码并保存到本地

需求:我要在一个页面中生成一个二维码,并且这个二维码可以长按保存到本地或者发送给好友;

我这里是将生成的canvas二维码转换成图片,利用长按图片进行保存或转发

效果图:

第一步先下载对应的包:

javascript 复制代码
npm install weapp-qrcode --save

第二步: wxml

我们需要准备一个生成二维码的canvas

javascript 复制代码
<canvas class="pf canvas" style="width:260rpx;height:260rpx;" canvas-id="myQrcode" id="myQrcode"></canvas>

canvas-id="myQrcode" 这个id是生成二维码的时候需要

id="myQrcode" 这个id是转换图片的时候需要

还需要一个存放图片的image (图片的位置自定义)

html 复制代码
<image show-menu-by-longpress="true" src="{{qrcodeUrl}}" mode="aspectFit"></image>

show-menu-by-longpress="true" 必须存在

第三步:JS

先导入weapp-qrcode包

javascript 复制代码
import drawQrcode from 'weapp-qrcode'

data中定义需要用到的变量

javascript 复制代码
data: {
    showCodeFn:false,
    qrcodeUrl:''
  },

开始生成二维码

javascript 复制代码
onLoad(options) {
var that = this
drawQrcode({
      width:130,
      height:130,
      canvasId: 'myQrcode',
      text: config.temporaryUrl+'wechat/unit/'+options.unitId,
      callback:function(e){
        //我这里判断如果二维码生成成功就调用转换图片的方法,万一在没生成二维码之前,用户点击了图片的,报错或者看不见就尴尬了
        that.drawImg()
      }
    })
 },

至于需要在哪个生命周期函数中生成二维码,自己定

将二维码转换成图片的方法

javascript 复制代码
drawImg(){
    var that = this
    // 创建一个选择器查询对象
    const query = wx.createSelectorQuery();
    // 执行查询并获取 canvas 节点的实例
    query.select('#myQrcode').boundingClientRect()
    // 查询结束后执行回调函数
    query.exec((res) => {
      if (res[0]) {
        // res[0] 是 canvas 节点信息,确保节点存在
        wx.canvasToTempFilePath({
          canvasId: 'myQrcode',
          success(res) {
            that.setData({
//因为的的需求是点击某个地方,才让图片显示,所以在没生成图片之前,先把需要点击的那个地方隐藏了,等生成图片成功后,再放出来,所以这里是控制那个点击地方的显示/隐藏
              showCodeFn:true
            })
            console.log('查询成功')
            const tempFilePath = res.tempFilePath;
            console.log(tempFilePath);
            that.setData({
//这是图片地址
              qrcodeUrl: tempFilePath
            })
          },
          fail(err) {
            console.error( err);
          }
        });
      } else {
        console.error('未能找到对应的 canvas 节点');
      }
    });
  },

完成 ✿✿ヽ(°▽°)ノ✿

相关推荐
蓝帆傲亦9 小时前
支付宝小程序性能暴增秘籍:UniApp项目极限优化全攻略
小程序·uni-app
CHU72903513 小时前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序
2501_9339072115 小时前
深圳本凡科技专业企业APP开发,助力手机应用创新优化
科技·微信小程序·小程序
每天都要加油呀!16 小时前
TypeError: uni.requestPayment is not a function
小程序
java1234_小锋17 小时前
分享一套优质的微信小程序校园志愿者系统(SpringBoot后端+Vue3管理端)
微信小程序·小程序·校园志愿者
2501_9160088918 小时前
深入解析iOS机审4.3原理与混淆实战方法
android·java·开发语言·ios·小程序·uni-app·iphone
打破砂锅问到底00718 小时前
AI 驱动开发实战:10分钟从零构建「微信群相册」小程序
人工智能·微信·小程序·ai编程
CHU72903519 小时前
扭蛋机盲盒小程序前端功能设计解析:打造趣味与惊喜并存的消费体验
前端·小程序
QT.qtqtqtqtqt19 小时前
uni-app小程序前端开发笔记(更新中)
前端·笔记·小程序·uni-app
CHU72903521 小时前
直播商城APP前端功能全景解析:打造沉浸式互动购物新体验
java·前端·小程序