iOS端video标签跳转播放时长黑屏

iOS 端 video 标签跳转播放时长黑屏

描述

环境:微信公众号网页
设备:ios 端
场景:video 标签通过 currentTime 跳转播放时长
问题:黑屏

需求

ios 端 video 标签,通过 currentTime 属性跳转播放时长后,元素为暂停状态且展示正常帧。

方案

思路

  1. 自动播放到指定时间,将元素状态设置为暂停
  2. 将 currentTime 属性设置为指代时长,将元素播放后,延迟时间再设置为暂停
  3. 将 currentTime 属性设置为指代时长,将元素状态设置为暂停

解决

在 ios 端 video 标签状态为播放时会全屏播放,因此思路1、思路2不可取。

思路3 代码
HTML 部分

<video
   class="video-el"
   ref="videoRef"
   :src="item"
   style="background-color: #000;"
   controls
   muted
   loop
   preload="metadata"
   controlslist="nodownload nofullscreen"
 ></video>

JS 部分

/**
 * @Description 检测用户设备类型
 * @param {type} 'android | ios'
 */
export function checkUserAgent(type) {
  const u = navigator.userAgent
  const isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1 //android终端
  const isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/) //ios终端

  const formatType = (type && type.toLocaleLowerCase()) || ''
  switch (formatType) {
    case 'android':
      return isAndroid
    case 'ios':
      return isIOS
    default:
      throw new Error(`请输入要检测用户设备的类型('android | ios')`)
  }
}
// 初始化播放
initPlayer() {
  // 检测用户设备类型是否为 iOS 端
  if (checkUserAgent('ios')) {
    if (window.WeixinJSBridge) {
      this.jumpCurrentTime()
    } else {
      document.addEventListener(
        'WeixinJSBridgeReady',
        function() {
          this.jumpCurrentTime()
        },
        false
      )
    }
  } else {
  	const videoEl = this.$refs.videoRef
  	if (videoEl) {
  		videoEl.currentTime = 0.2
  	}
  }
}

// 跳转当前播放时长
jumpCurrentTime() {
   window.WeixinJSBridge.invoke('getNetworkType', {}, function() {
   	 let videoEl = document.querySelector('.video-el')
	 if (videoEl ) {
	 	videoEl.currentTime = 0.2
     	videoEl.pause()
	 }
   })
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您好!关于您提到的问题,可能原因有以下几个:1.视频格式不支持,2.视频文件路径不正确,3.视频文件下载不完整或损坏。建议您先检查您的视频文件是否可以在其他设备或浏览器上正常播放。如果可以,再检查一下代码中的视频路径和格式是否正确。如果还是无法解决问题,可以提供更多细节信息,以便更好地帮助您解决问题。谢谢! ### 回答2: 在iOS使用video标签播放视频失败可能有多个原因。以下是一些可能的原因和解决方案: 1. 浏览器兼容性问题:iOS系统使用的是Safari浏览器,它对于video标签的支持可能受到限制。首先,确保你使用的是最新版本的Safari浏览器。如果问题仍然存在,尝试使用其他第三方浏览器或者通过WebView组件来播放视频。 2. 视频格式不受支持:iOS通常支持播放常见的视频格式,如MP4。确保你的视频文件使用的是受支持的格式,并且编码设置正确。如果不确定视频格式是否正确,可以尝试使用其他格式进行测试。 3. 媒体服务器配置问题:如果你的视频是从远程媒体服务器加载的,确保服务器的配置正确。特别是检查MIME类型是否正确设置为video/mp4或其他支持的视频格式。 4. 网络连接问题:如果你的网络连接不稳定或者速度较慢,可能会导致视频加载失败。尝试连接其他稳定快速的网络来检查问题是否解决。 5. JavaScript或CSS代码问题:检查你的代码中是否有语法错误或者逻辑问题,可能会导致视频无法正确加载或播放。 如果以上解决方案都没有解决问题,建议查阅相关的开发文档,尝试通过调试工具来查找具体的错误信息和解决方案。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值