日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue js前端根据所需参数生成二维码并下载

發布時間:2023/12/31 vue 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue js前端根据所需参数生成二维码并下载 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
  • 需要一個插件 qrcodejs2, 使用 npm install qrcodejs2 --save 下載該依賴包。
  • 在vue中引入(我這邊是vue2)。import QRCode from 'qrcodejs2';
  • 在計算屬性中使用它。
  • computed: {QRCode,},
  • 在dom結構中設置一個容器來承載它,并設置一個id.
  • <div id="qrcode" style="display: none"></div> // 如果要顯示這個二維碼就不要設置display:none

    然后可以在需要下載生成二維碼的地方觸發這個事件

  • 生成二維碼。
  • qrcode(val) { // 生成二維碼函數document.getElementById('qrcode').innerHTML = ''; // 清空dom元素內容,防止污染canvas const qrcode = new QRCode('qrcode', {width: 200,height: 200, // 高度text: 'http://wx.qlogo.cn/mmhead/Q3auHgzCEVqspSUMou272WfP9OAJ1dNl0zr6uQ/0xxx', // 二維碼內容 這個自己跟換地址 內容// render: 'canvas' , // 設置渲染方式(有兩種方式 table和canvas,默認是canvas)background: '#f0f', // 背景色foreground: '#ff0', // 前景色});console.log(qrcode, 'qrcode');this.saveImg(); // 下載函數return qrcode;// console.log(qrcode, '444444');},
  • 生成二維碼后就調用下載(如果你們只需要生成二維碼就不需要這步)
  • saveImg() {// 找到canvas標簽const cvs = document.getElementById('qrcode').getElementsByTagName('canvas');console.log(cvs, '[[');// 創建一個a標簽節點const a = document.createElement('a');// 設置a標簽的href屬性(將canvas變成png圖片)a.href = cvs[0].toDataURL('image/png').replace('image/png', 'image/octet-stream');// 設置下載文件的名字a.download = 'qrcode.png';// 點擊a.click();},

    到此就完成了前端根據參數生成二維碼,并下載。

    項目需求 使用element 表格 來動態生成二維碼,要求鼠標移入時顯示二維碼。
    注意這里code 函數是放在 methods 里面的,不要試圖使用計算屬性來觸發,有可能會重復渲染二維碼。

    截出部分項目中代碼

    <template v-if="item.prop === 'linkCodeUrl'" #default="{ $index }"><p class="p" @click="copy(data[$index])">復制鏈接</p><el-popover popper-class="cloud-qrcode" placement="right" width="200" trigger="hover"><div :id="`qrcode${$index}`"></div><spanslot="reference"class="p"@click="downloadCode(data[$index], $index)"@mouseover="code(data[$index].id, $index)">下載二維碼</span></el-popover></template>

    js部分

    code(val, index) {console.log(index, 'pindex');this.$nextTick(() => {document.getElementById(`qrcode${index}`).innerHTML = '';const url = xxxxxx?id=${val}`;const qrcode = new QRCode(`qrcode${index}`, {width: 200,height: 200,text: url,background: '#f0f',foreground: '#ff0',});return qrcode;});},

    效果圖:

    總結

    以上是生活随笔為你收集整理的vue js前端根据所需参数生成二维码并下载的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。