wo-user-part-uniapp/ucQrcode/ucQrcode.vue

215 lines
12 KiB
Vue
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!--
Based on tki-qrcode 组件 https://github.com/q310550690/uni-app-qrcode , https://ext.dcloud.net.cn/plugin?id=39
// 另一个app里二维码解决方案但要手动调用生成函数: https://github.com/alei817927/qrcode
// 另一个h5里二维码解决方案import VueQriously from 'vue-qriously'; Vue.use(VueQriously)
-->
<template xlang="wxml" minapp="mpvue">
<view class="cQrcode">
<!-- #ifndef MP-ALIPAY -->
<canvas class="cQrcode-canvas" :canvas-id="cid" :style="{width:cpSize+'px',height:cpSize+'px'}" />
<!-- #endif -->
<!-- #ifdef MP-ALIPAY -->
<canvas :id="cid" :width="cpSize" :height="cpSize" class="cQrcode-canvas" />
<!-- #endif -->
<image v-show="show" :src="result" :style="{width:cpSize+'px',height:cpSize+'px'}" />
</view>
</template>
<script>
import QRCode from "./qrcode.js"
let qrcode
export default {
props: {
cid: {
type: String,
default: 'cQrcodeCanvas'
},
size: {
type: [Number, String],
default: 200
},
unit: {
type: String,
default: 'px'
},
show: {
type: [Boolean, String],
default: true
},
val: {
type: String,
default: ''
},
background: {
type: String,
default: '#ffffff'
},
foreground: {
type: String,
default: '#000000'
},
pdground: {
type: String,
default: '#000000'
},
icon: {
type: String,
default: ''
},
iconSize: {
type: [Number, String],
default: 40
},
lv: {
type: [Number, String],
default: 3
},
onval: {
type: [Boolean, String],
default: true
},
loadMake: {
type: [Boolean, String],
default: true
},
usingComponents: {
type: [Boolean, String],
default: true
},
showLoading: {
type: [Boolean, String],
default: false
},
loadingText: {
type: String,
default: '......'
},
},
data() {
return {
result: '' // '../static/cQrcode.loading.png',
}
},
methods: {
_makeCode() {
let that = this
if (!this._empty(this.val)) {
qrcode = new QRCode({
context: that, // 上下文环境
canvasId:that.cid, // canvas-id
usingComponents: that.usingComponents===true||that.usingComponents==='true', // 是否是自定义组件
showLoading: that.showLoading===true||that.showLoading==='true', // 是否显示loading
loadingText: that.loadingText, // loading文字
text: that.val, // 生成内容
size: that.cpSize, // 二维码大小
background: that.background, // 背景色
foreground: that.foreground, // 前景色
pdground: that.pdground, // 定位角点颜色
correctLevel: Number(that.lv), // 容错级别
image: that.icon, // 二维码图标
imageSize: Number(that.iconSize),// 二维码图标大小
cbResult: function (res) { // 生成二维码的回调
that._result(res)
},
});
} else {
uni.showToast({
title: '二维码内容不能为空',
icon: 'none',
duration: 2000
});
}
},
_clearCode() {
this._result('')
qrcode.clear()
},
_saveCode() {
let that = this;
if (this.result != "") {
uni.saveImageToPhotosAlbum({
filePath: that.result,
success: function () {
uni.showToast({
title: '二维码保存成功',
icon: 'success',
duration: 2000
});
}
});
}
},
_result(res) {
this.result = res;
this.$emit('result', res)
},
_empty(v) {
let tp = typeof v,
rt = false;
if (tp == "number" && String(v) == "") {
rt = true
} else if (tp == "undefined") {
rt = true
} else if (tp == "object") {
if (JSON.stringify(v) == "{}" || JSON.stringify(v) == "[]" || v == null) rt = true
} else if (tp == "string") {
if (v == "" || v == "undefined" || v == "null" || v == "{}" || v == "[]") rt = true
} else if (tp == "function") {
rt = false
}
return rt
}
},
watch: {
size: function (n, o) {
if (n != o && !this._empty(n)) {
this.cSize = n
if (!this._empty(this.val)) {
setTimeout(() => {
this._makeCode()
}, 100);
}
}
},
val: function (n, o) {
if (this.onval===true || this.onval==='true') {
if (n != o && !this._empty(n)) {
setTimeout(() => {
this._makeCode()
}, 0);
}
}
}
},
computed: {
cpSize() {
if(this.unit == "upx"){
return uni.upx2px(this.size)
}else{
return this.size
}
}
},
mounted: function () {
if (this.loadMake===true || this.loadMake==='true') {
if (!this._empty(this.val)) {
setTimeout(() => {
this._makeCode()
}, 0);
}
}
},
}
</script>
<style>
.cQrcode {
position: relative;
}
.cQrcode-canvas {
position: fixed;
top: -99999upx;
left: -99999upx;
z-index: -99999;
}
</style>