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

农民  论坛元老 | 2025-1-16 22:54:50 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 1016|帖子 1016|积分 3048

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
现象:
1、点击遮罩弹窗关闭,弹窗的视频已经用v-if销毁,但是后台会自己从头开始播放视频声音。但是此时已经没有视频dom
2、定时器在打开弹窗后3秒主动关闭弹窗,则正常没有问题。
原来的代码:
  1. //页面
  2. <a @click="handleOpen()">点我打开弹窗</>
  3. <van-popup v-model="isShow" v-if="isShow"  get-container="body" @click-overlay="handleVideoClose">
  4.         <div class="container">
  5.           <video v-if="isShow" id="videoPlay" class="video" controls autoplay="autoplay" :src="videoSrcs" preload></video>
  6.         </div>
  7.       </van-popup>
  8. //方法
  9. async handleOpen() {
  10.       this.videoSrcs =‘http://视频链接’
  11.       this.isShow= true
  12. }
  13. handleVideoClose(){
  14.   document.getElementById('videoPlay').pause()
  15.   this.isShow= false
  16. },
复制代码
解决结果:
将video的autoplay属性去掉,使用.play()解决。但是还是没太懂原因,求各位大佬辅导!!!
正常运行代码:
  1. //页面
  2. <a @click="handleOpen()">点我打开弹窗</>
  3. <van-popup v-model="isShow" v-if="isShow"  get-container="body" @click-overlay="handleVideoClose">
  4.         <div class="container">
  5.           <video v-if="isShow" id="videoPlay" class="video" controls :src="videoSrcs" preload></video>
  6.         </div>
  7.       </van-popup>
  8. //方法
  9. async handleOpen() {
  10.       this.videoSrcs =‘http://视频链接’
  11.       this.isShow= true
  12.       this.$nextTick(()=>{
  13.         document.getElementById('videoPlay').play()
  14.       })
  15. }
  16. handleVideoClose(){
  17.   document.getElementById('videoPlay').pause()
  18.   this.isShow= false
  19. },
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

农民

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表