vue生成二维码并下载[通俗易懂]

vue生成二维码并下载[通俗易懂]vue生成二维码图片,这里使用的是qrcode.js这个插件1、下载插件npminstall–saveqrcodejs22、组件内使用<template><Buttontype=”primary”size=”small”@click=”getScan()”>扫一扫</Button><Buttontype=”primary”size=”small”@click=”getDownload()”>下载</Bu..

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

vue生成二维码图片,这里使用的是qrcode.js 这个插件

1、下载插件

npm install --save qrcodejs2

2、组件内使用

<template>
  <Button type=”primary” size=”small” @click=”getScan()”>扫一扫</Button>
  <Button type=”primary” size=”small” @click=”getDownload()”>下载</Button>
  <Button type=”primary” size=”small” @click=”getPrinting()”>打印</Button> <!–二维码–>

  <div id=”qrcode”></div>

</template>

3、<script>

import QRCode from ‘qrcodejs2’;
export default {

  name:’tracing’,
  data(){

    return{}
  },
  methods:{

    // 生成二维码
    qrcode(){

        let qrcode = new QRCode(‘qrcode’, {

            width: 200,
            height: 200, // 高度
            text:”二维码内容” 
      })
    },
    // 查看二维码
    getScan(){

       // 清空之前生成的二维码
      document.getElementById(‘qrcode’).innerHTML=”;
      this.$nextTick(()=>{

        this.qrcode();//生成二维码
      })
    },
    // 下载二维码
    getDownload(){    this.qrcode(); //下载之前首先要有二维码
      // 先找到canvas节点下的二维码图片
      let myCanvas = document.getElementById(‘qrcode’).getElementsByTagName(‘canvas’);
      let img=document.getElementById(‘qrcode’).getElementsByTagName(‘img’);
      // 创建一个a节点
      let a = document.createElement(‘a’);
      // 设置a的href属性将canvas变成png格式
      let imgURL=myCanvas[0].toDataURL(‘image/jpg’);
      let ua = navigator.userAgent;
      if (ua.indexOf(“Trident”) != -1 && ua.indexOf(“Windows”) != -1) { // IE内核 并且  windows系统 情况下 才执行;
        var bstr = atob(imgURL.split(‘,’)[1])
        var n = bstr.length
        var u8arr = new Uint8Array(n)
        while (n–) {

          u8arr[n] = bstr.charCodeAt(n)
        }
        var blob = new Blob([u8arr])
        window.navigator.msSaveOrOpenBlob(blob, ‘下载’ + ‘.’ + ‘png’)
      }else if(ua.indexOf(“Firefox”) > -1){ //火狐兼容下载
        let blob = this.base64ToBlob(imgURL); //new Blob([content]);
        let evt = document.createEvent(“HTMLEvents”);
        evt.initEvent(“click”, true, true);//initEvent 不加后两个参数在FF下会报错  事件类型,是否冒泡,是否阻止浏览器的默认行为
        a.download = ‘ ‘;//下载图片名称,如果填内容识别不到,下载为未知文件,所以我这里就不填为空
        a.href = URL.createObjectURL(blob);
        a.dispatchEvent(new MouseEvent(‘click’, {bubbles: true, cancelable: true, view: window}));//兼容火狐
      }else{ //谷歌兼容下载
        img.src=myCanvas[0].toDataURL(‘image/jpg’);
        // a.href = myCanvas[0].toDataURL(‘image/png’).replace(‘image/png’, ‘image/octet-stream’)
        a.href=img.src
        //设置下载文件的名字
        a.download = “下载”
         //点击
        a.click()
      }
    },
  // 打印二维码  getPrinting(){    let employeeName = “溯源信息”;
    let printContent = `<td >      <div style=”text-align: center;margin:0 0 10px;border:1px solid #ccc;padding:10px;width:300px” id=’XQ’></div>      <div style=”text-align: center;margin:0 0 10px;width:300px” >        <strong>${employeeName}</strong>      </div>

        </td>`;
      document.getElementById(“qrcode”).innerHTML = printContent;
      let new_str = document.getElementById(“qrcode”).innerHTML; //获取指定打印区域
      //构建新网页(关键步骤,必须先构建新网页,在生成二维码,否则不能显示二维码)
      document.body.innerHTML = new_str;
      for (let j = 0; j < 1; j++) {

        document.getElementById(“XQ”).innerHTML = “”; //置空
        new QRCode(document.getElementById(“XQ”), {

            text: “dfjkdjdfjak123456789”,
            width: 250,
            height: 250,
            colorDark: “#000000”,
            colorLight: “#ffffff”,
        });
      }
      window.print(); //打印刚才新建的网页
      window.location.reload();
      return false;

    },
    //base64转blob
    base64ToBlob(code) {

      let parts = code.split(‘;base64,’);
      let contentType = parts[0].split(‘:’)[1];
      let raw = window.atob(parts[1]);
      let rawLength = raw.length;
      let uInt8Array = new Uint8Array(rawLength);
      for (let i = 0; i < rawLength; ++i) {

      uInt8Array[i] = raw.charCodeAt(i);
      }
      return new Blob([uInt8Array], {type: contentType});
    }
  }
}
</script>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/186331.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Mount NTFS Partitions

    Mount NTFS PartitionsMountNTFSPartitions18January2007Windowsusesadifferentfilesystem(NTFS)tostorefiles.InorderforFedoratoreadthatfilesystem,yourequireNTFSsupportinyourkernel.Youcaneither

    2022年6月26日
    39
  • h5 iframe嵌套页面_汇总IOS下奇葩BUG以及iframe嵌套页面带来的一些困扰

    h5 iframe嵌套页面_汇总IOS下奇葩BUG以及iframe嵌套页面带来的一些困扰做H5开发,安卓和IOS的兼容问题经常会困扰我们,尤其是跟第三方平台合作,用到iframe嵌入式应用,令很多Web前端开发的童鞋脑壳疼,相信大家也入了不少坑,且踩且珍惜吧,呵呵^_^。今天抽时间整理一些出来,希望能帮助到大家。iframe自动变宽了,在IOS手机上出现滚动条第一步:定义iframe中的scrolling属性为no,设置iframe中不显示滚动条。第二步:设置iframe的样式为…

    2022年6月17日
    191
  • 【后端】Object转String的4种方法

    【后端】Object转String的4种方法Object转String的4种方法,Object转Long或者int,Object怎么转成String,Java转换String的方法,Java怎么转String,怎么转换成String类型

    2025年6月21日
    4
  • JAVA遍历数组的三种方法_如何遍历一个数组

    JAVA遍历数组的三种方法_如何遍历一个数组我们也了解Java也已经很久了,那今天小编想问大家是否知道java遍历数组的方式有哪些?是不是内心已经已经有答案了?让就跟着小编的步伐一起看看吧。1.for循环遍历这是最基本的遍历方式通常遍历数组都是使用for循环来实现。遍历一维数组很简单,遍历二维数组需要使用双层for循环,通过数组的length属性可获得数组的长度。2.Arrays的toString方法debug快速查看方法利用Array…

    2026年1月26日
    3
  • python中0xf_Python 0xff作者

    python中0xf_Python 0xff作者我有个错误:UnicodeDecodeError:’utf-8’codeccan’tdecodebyte0xffinposition:0,invalidstartbyte我找到了这个解决方案:^{pr2}$但是如果a)你不知道0xff在哪里和/或b)你需要解码一个file对象,你怎么使用它呢?正确的语法/格式是什么?在我正在解析一个目录,所以我试着一次检查一个文件。(注意:…

    2022年6月19日
    28
  • ceph osd heartbeat 分析

    ceph osd heartbeat 分析Introduction 大规模分布式系统中 各种异常情况时有发生 如系统宕机 网络故障 磁盘损坏等等都有可能造成集群内部节点无法通信 一个分布式系统要正常协调地运转 内部各节点进程间需要通过心跳机制来保证各节点处于正常工作状态 一旦发现故障 及时响应 本文简单对 cephosd 进程间的心跳机制加以分析 HeartBeatMes 进程间心跳消息 需要通过 ceph 网络层

    2025年9月30日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号