h5使用video播放时关掉vant弹窗视频声音还在后台播放

现象:

1、点击遮罩弹窗关闭,弹窗的视频已经用v-if销毁,但是后台会自己从头开始播放视频声音。但是此时已经没有视频dom

2、定时器在打开弹窗后3秒自动关闭弹窗,则正常没有问题。

原来的代码:

javascript 复制代码
//页面
<a @click="handleOpen()">点我打开弹窗</>
<van-popup v-model="isShow" v-if="isShow"  get-container="body" @click-overlay="handleVideoClose">
        <div class="container">
          <video v-if="isShow" id="videoPlay" class="video" controls autoplay="autoplay" :src="videoSrcs" preload></video>
        </div>
      </van-popup>

//方法
async handleOpen() {
      this.videoSrcs ='http://视频链接'
      this.isShow= true
}
handleVideoClose(){
  document.getElementById('videoPlay').pause()
  this.isShow= false
},

解决结果:

将video的autoplay属性去掉,使用.play()解决。但是还是没太懂原因,求各位大佬指点!!!

正常运行代码:

javascript 复制代码
//页面
<a @click="handleOpen()">点我打开弹窗</>
<van-popup v-model="isShow" v-if="isShow"  get-container="body" @click-overlay="handleVideoClose">
        <div class="container">
          <video v-if="isShow" id="videoPlay" class="video" controls :src="videoSrcs" preload></video>
        </div>
      </van-popup>

//方法
async handleOpen() {
      this.videoSrcs ='http://视频链接'
      this.isShow= true
      this.$nextTick(()=>{
        document.getElementById('videoPlay').play()
      })
}
handleVideoClose(){
  document.getElementById('videoPlay').pause()
  this.isShow= false
},
相关推荐
Seraphim6 分钟前
UniApp,在微信小程序下,使用Hook来完成分享
前端
一枚前端小能手14 分钟前
🚀 浏览器兼容性问题的5个解决方案 - 让你的代码在所有浏览器都完美运行
前端
越前君16 分钟前
如何开发一个 Raycast 扩展?
前端·笔记
Spider_Man17 分钟前
React 组件缓存与 KeepAlive 组件打造全攻略 😎
前端·react.js·typescript
littleplayer18 分钟前
Swift: Combine的错误处理
前端·架构
前端灵派派19 分钟前
openlayer实现定位闪烁
前端
K歌、之王19 分钟前
ubuntu20搭建MQTT
前端·chrome
萌萌哒草头将军20 分钟前
Node.js v24.7.0 新功能预览 🚀🚀🚀
前端·javascript·node.js
用户8417948145621 分钟前
vue table 甘特图 vxe-gantt 实现多个表格的任务互相拖拽数据
vue.js
然我21 分钟前
性能优化保姆级指南,一篇搞定所有考点💯
前端·面试·性能优化