安装
npm install html5-qrcode
代码
<template>
<view class="container">
<button class="scan" @click="scancode">打开相机扫码</button>
<view class="reader-box" v-if="isscaning">
<view class="reader" id="reader"></view>
</view>
</view>
</template>
<script>
import {
html5qrcode
} from 'html5-qrcode';
export default {
data() {
return {
html5qrcode: null,
isscaning: false,
}
},
methods: {
startscan() {
this.isscaning = true;
html5qrcode.getcameras().then(devices => {
if (devices && devices.length) {
this.html5qrcode = new html5qrcode('reader');
this.html5qrcode.start({
facingmode: 'environment',
}, {
fps: 24,
qrbox: 280
}, (decodetext, decoderesult) => {
console.log(decodetext)
if (decodetext) {
this.stopscan();
this.isscaning = false;
}
}, (err) => {
console.log(err)
});
}
});
},
stopscan() {
this.html5qrcode.stop();
},
scancode() {
console.log('helo')
this.startscan();
}
}
}
</script>
<style scoped>
.container{
height:100%;
}
.reader-box {
position: fixed;
top: 0;
bottom: 0;
left: 0;
right: 0;
background-color: rgba(0, 0, 0, 0.5);
}
.reader {
width: 540rpx;
height: 540rpx;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
</style>测试效果
uniapp运行到浏览器


到此这篇关于uniapp在h5页面实现扫码功能(html5-qrcode)的文章就介绍到这了,更多相关html5 qrcode扫码内容请搜索代码网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持代码网!
发表评论