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

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

我这里是将生成的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 节点');
      }
    });
  },

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

相关推荐
ALLSectorSorft5 小时前
上门送水小程序区域代理模块框架设计
小程序
wuyijysx5 小时前
微信小程序 binding
微信小程序·小程序
ALLSectorSorft11 小时前
家政小程序预约系统框架设计
小程序
编程毕设11 小时前
【含文档+PPT+源码】基于微信小程序健康管理之健身房管理系统的设计与实现
微信小程序·小程序
大叔_爱编程15 小时前
wx219基于ssm+vue+uniapp的教师管理系统小程序
vue.js·小程序·uni-app·毕业设计·ssm·源码·课程设计
f(me)17 小时前
如何保障企业数据的安全?软件开发中的数据安全防护措施
网络安全·小程序
small_fox_dtt17 小时前
微信小程序转为App实践篇 FinClip
微信小程序·小程序
2401_8979300617 小时前
微信小程序中大型项目开发实战指南
微信小程序·小程序
小咕聊编程18 小时前
【含文档+PPT+源码】基于微信小程序的学校体育馆操场预约系统的设计与实现
微信小程序·小程序
说私域1 天前
开源链动2+1模式、AI智能名片与S2B2C商城小程序融合下的社交电商营销新范式
人工智能·小程序·开源·零售