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
},
相关推荐
光影少年25 分钟前
vite+rust生态链工具链
开发语言·前端·后端·rust·前端框架
skywalk816325 分钟前
当前有什么流行的lisp的web框架吗?
开发语言·前端·lisp
IT_陈寒31 分钟前
为什么我的JavaScript变量老是不听使唤?
前端·人工智能·后端
HookJames34 分钟前
设计Section 06 · Component Sourcing & BOM Risk Control
前端
zhenxin012235 分钟前
HTML头部元信息避坑指南
前端·html
ai产品老杨35 分钟前
【深度架构解析】高并发 AI 视频管理平台:兼容 GB28181/RTSP,支持 X86/ARM+GPU/NPU 异构部署与源码交付
人工智能·架构·音视频
qq_5469372736 分钟前
完全免费的离线运行的本地音视频转字幕工具,支持一键音视频提取文字,可以导出多种格式!
音视频
布局呆星1 小时前
Vite代理解决前端跨域问题 | fetch请求 | 环境变量
前端
AI服务老曹1 小时前
从GB28181接入到边缘NPU算力调度:深度解析支持异构计算的工业级AI视频管理平台架构
人工智能·架构·音视频
sghuter1 小时前
HTML头部元信息避坑指南
c语言·前端·html·cocoa