Vue3 使用audio播放语音+监听播放语音完成事件

需求:输入一段文字,点击语音框,将本地语音(提前准备好的) 播放出来

在这里插入图片描述

播放中效果

在这里插入图片描述

代码

 <div  class="listConAI"  @click="handleOpenSpeech" >
      <img
        src="../../../../assets/images/blueopen.png" class="blueopenIcon" >
      <img
        :src="openVoice == true ? voiceUrl : voiceDefalutUrl" class="voiceIcon" >
      <audio
        @ended="onAudioEnded"
        ref="audio"
        :src="voicePath"
        controls
        hidden="true"
      ></audio>
    </div>

tips: 因为我这个语音条要自定义样式,所以给audio使用了 隐藏属性哈~

<script setup>
import { useI18n } from 'vue-i18n';
import { ref,nextTick } from 'vue'
const loading = ref(false)
const openVoice = ref(false)
const voiceDefalutUrl = require('../../../../assets/images/openVoice.png');
const voiceUrl = require('../../../../assets/images/voice.gif');
const audio = ref(new Audio())
const voicePath = ref('')
const handleOpenSpeech = () => {
  openVoice.value = true
  // 本地链接
  voicePath.value = new URL(require('../../../../assets/music/success.mp3'), import.meta.url).href
  nextTick(() => {
    console.log(audio.value, 'audio')
    audio.value?.play()
  })
}
//监听语音播放完成方法,将语音条图片显示状态修改回来
const onAudioEnded = () => {
  openVoice.value = false
};
</script>

Tips: 如果播放语音组件在 列表页面中使用 播放语音方法 要适当修改

例子:

   <div class="listConAI"  @click="handleOpenSpeech(item.msg)" >
            <img
              src="../../../assets/images/blueopen.png"
              class="blueopenIcon"
            >
            <img
              :src="openVoice == true ? voiceUrl : voiceDefalutUrl"
              class="voiceIcon"
            >
            <audio
              ref="audio"
              :src="voicePath"
              controls
              hidden="true"
            ></audio>
          </div>
const handleOpenSpeech = (value) => {
  openVoice.value = !openVoice.value
  // 本地链接
  voicePath.value = new URL(value, import.meta.url).href
  nextTick(() => {
    console.log(audio.value, 'audio')
    audio.value[0]?.play()
  })
}
  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值