audio的play属性在第一次操作失效

15 篇文章 0 订阅
4 篇文章 0 订阅

audio的play属性在第一次操作失效,在第二次操作后恢复正常

最近在写一个音乐网站,我希望页面呈现的效果是点击按钮A,audio实现播放:
在这里插入图片描述
于是我在按钮A所在的组件,为它绑定一个点击事件,触发事件playMusic:

music(play, index) {
            ......
            this.$bus.$emit("playMusic")
            ......

在playMusic里:

this.$bus.$on("playMusic", () => {
            console.log(this.$refs.audio_music)
            this.playPause()
        })

playPause() {
            if (this.isPlay) { //暂停音乐
                ...
                    this.$refs.audio_music.pause();
                ...
            } else { // 播放音乐
		            ......
                this.$refs.audio_music.play();
                ......
            }

照理来说,初次点击按钮就会调用play(),并播放音频,但我却得到如下结果:
在这里插入图片描述只有在第二次及以上点击按钮A才能实现正常功能。

后面我为audio添加了一个自动播放的属性,就解决了

<audio :src="getSongUrl(songList[songIndex].url)" 
		controls="controls" 
		ref="audio_music" 
		style="display:"
    	autoplay muted>
</audio>

无论我和页面是否有交互,只要是切换到新的资源,就会出现上述错误,于是我打算先记录下来。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值