zoukankan      html  css  js  c++  java
  • vue2.0生成二维码图片并且下载图片到本地兼容写法

    vue生成二维码图片,这里使用的是qrcode.js 这个插件(亲测写法,兼容没有问题)

    第一步,下载插件

    需要注意,这里下载的是qrcodejs2

    cnpm install --save qrcodejs2

    第二步,在组件使用

    <template>
      <div>
        <div @click="getQrcode"></div>//生成二维码
        <div id="qrcode"></div> //创建一个div,并设置id为qrcode 
        <div @click="downs()"></div> //下载图片
      </div>
    </template>
    <script>
    import QRCode from 'qrcodejs2'  // 引入qrcode
    export default {
        name : 'test',
      data(){
        return{
             link: 'http://test.wx.jia-r.com/temporaryCarIndex.html' //需要生成二维码图片的字符串
          },
      }

      components:{QRCode },   methods: { getQrocde(){ document.getElementById(
    'qrcode').innerHTML='' this.$nextTick (function () {//生成二维码 this.qrcode(); }) }, qrcode () { let that = this; let qrcode = new QRCode('qrcode', { 200, height: 200, // 高度 text: this.link, // 二维码内容 // render: 'canvas' , // 设置渲染方式(有两种方式 table和canvas,默认是canvas) // background: '#f0f', // 背景色 // foreground: '#ff0' // 前景色 }) }, downs(){ // //找到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() } }, //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>

     这里分享一个小技巧,通过qrcode生成的二维码本身是没有白边的,这样的二维码并不好看↓

     

     如果想像这样生成一个有白边的二维码,是不是更好看一点,只需要通过css样式即可实现↓

    代码如下:

    <style lang='less'>
     #qrcode { //图片有白边填充css
        display: inline-block;
        img {
           132px;
          height: 132px;
          background-color: #fff; //设置白色背景色
          padding: 6px; // 利用padding的特性,挤出白边
        }
      }
    </style>

    结束!!

  • 相关阅读:
    【Java TCP/IP Socket】应用程序协议中消息的成帧与解析(含代码)
    【Java TCP/IP Socket】UDP Socket(含代码)
    【Java TCP/IP Socket】TCP Socket(含代码)
    Java NIO —— Buffer(缓冲区)
    java.nio.ByteBuffer 以及flip,clear及rewind区别
    Java文件IO操作应该抛弃File拥抱Paths和Files
    Java网络编程之InetAddress和URL
    Java enum的用法详解
    PAT Basic 1083 是否存在相等的差 (20 分)
    PAT Basic 1082 射击比赛 (20 分)
  • 原文地址:https://www.cnblogs.com/ganws/p/11149668.html
Copyright © 2011-2022 走看看