当前位置:首页 > VUE

vue实现扫码

2026-01-08 06:50:06VUE

Vue 实现扫码功能

使用 vue-qrcode-reader

安装 vue-qrcode-reader 库:

npm install vue-qrcode-reader

在 Vue 组件中引入并使用:

vue实现扫码

<template>
  <div>
    <qrcode-stream @decode="onDecode"></qrcode-stream>
    <p>扫描结果: {{ result }}</p>
  </div>
</template>

<script>
import { QrcodeStream } from 'vue-qrcode-reader'

export default {
  components: { QrcodeStream },
  data() {
    return {
      result: ''
    }
  },
  methods: {
    onDecode(decodedString) {
      this.result = decodedString
    }
  }
}
</script>

使用 html5-qrcode

安装 html5-qrcode 库:

npm install html5-qrcode

在 Vue 组件中实现扫码:

vue实现扫码

<template>
  <div>
    <div id="qr-reader" style="width: 500px"></div>
    <p>扫描结果: {{ result }}</p>
  </div>
</template>

<script>
import { Html5Qrcode } from 'html5-qrcode'

export default {
  data() {
    return {
      result: ''
    }
  },
  mounted() {
    const html5Qrcode = new Html5Qrcode('qr-reader')
    html5Qrcode.start(
      { facingMode: 'environment' },
      { fps: 10, qrbox: 250 },
      (decodedText) => {
        this.result = decodedText
      },
      (errorMessage) => {
        console.error(errorMessage)
      }
    )
  }
}
</script>

使用原生 API 实现

通过浏览器原生 API 调用摄像头并解析二维码:

<template>
  <div>
    <video ref="video" width="400" height="300" autoplay></video>
    <canvas ref="canvas" width="400" height="300" style="display: none"></canvas>
    <button @click="scanQR">开始扫描</button>
    <p>扫描结果: {{ result }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      result: '',
      interval: null
    }
  },
  methods: {
    async scanQR() {
      const stream = await navigator.mediaDevices.getUserMedia({ video: true })
      this.$refs.video.srcObject = stream

      this.interval = setInterval(() => {
        const canvas = this.$refs.canvas
        const context = canvas.getContext('2d')
        context.drawImage(this.$refs.video, 0, 0, canvas.width, canvas.height)
        const imageData = context.getImageData(0, 0, canvas.width, canvas.height)
        // 这里需要添加二维码解析逻辑
        // 可以使用第三方库如 jsQR 来解析
      }, 500)
    }
  },
  beforeDestroy() {
    if (this.interval) clearInterval(this.interval)
    if (this.$refs.video.srcObject) {
      this.$refs.video.srcObject.getTracks().forEach(track => track.stop())
    }
  }
}
</script>

移动端适配

对于移动端设备,需要考虑权限请求和横竖屏适配:

<template>
  <div class="scanner-container">
    <qrcode-stream
      @decode="onDecode"
      :torch="torchActive"
      @torch-compatibility="onTorchCompatibility"
    ></qrcode-stream>
    <button @click="toggleTorch">切换闪光灯</button>
  </div>
</template>

<script>
import { QrcodeStream } from 'vue-qrcode-reader'

export default {
  components: { QrcodeStream },
  data() {
    return {
      result: '',
      torchActive: false,
      hasTorch: false
    }
  },
  methods: {
    onDecode(decodedString) {
      this.result = decodedString
    },
    onTorchCompatibility({ compatible }) {
      this.hasTorch = compatible
    },
    toggleTorch() {
      if (this.hasTorch) {
        this.torchActive = !this.torchActive
      }
    }
  }
}
</script>

<style>
.scanner-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
</style>

以上方法提供了从简单到复杂的多种实现方案,可以根据项目需求选择合适的方案。对于生产环境,推荐使用成熟的第三方库如 vue-qrcode-readerhtml5-qrcode,它们已经处理了大多数兼容性和性能问题。

标签: vue
分享给朋友:

相关文章

vue页面分离的实现

vue页面分离的实现

Vue页面分离的实现方法 将Vue页面分离为多个组件或模块,有助于提升代码可维护性和复用性。以下是几种常见的实现方式: 组件化拆分 通过将页面拆分为多个子组件,每个组件负责特定功能或UI部分。使用…

vue实现打字机

vue实现打字机

Vue实现打字机效果 在Vue中实现打字机效果可以通过动态更新文本内容并添加延迟来实现。以下是几种常见的实现方法: 使用setInterval实现 <template> <di…

vue搜索过后实现分页

vue搜索过后实现分页

Vue 实现搜索后分页功能 数据绑定与搜索逻辑 在 Vue 组件中定义必要的数据属性: data() { return { searchQuery: '', currentPa…

vue实现导航栏切图

vue实现导航栏切图

Vue 实现导航栏切图 使用 Vue Router 实现基础导航 在 Vue 项目中,可以通过 Vue Router 实现导航栏的路由切换。创建一个导航栏组件,并在其中使用 <router-li…

vue实现活动倒计时

vue实现活动倒计时

实现活动倒计时的基本思路 在Vue中实现活动倒计时通常需要获取当前时间与活动结束时间的差值,并将其转换为天、小时、分钟、秒的格式展示。通过定时器每秒更新显示的时间。 定义倒计时数据 在Vue组件的…

vue实现双折线图

vue实现双折线图

实现双折线图的步骤 安装必要的依赖库(如 ECharts 或 Chart.js),这里以 ECharts 为例: npm install echarts --save 在 Vue 组件中引入 EC…