H5页面在手机浏览器上无法播放视频或无法切换视频源的解决方案

本文探讨了在部分手机浏览器中H5视频无法播放及切换源的问题。问题根源在于网络协议,H5页面在某些环境下仅支持http协议播放视频。解决方案是确保video标签使用http链接,并在服务器配置相应映射。此外,切换视频源时,不应使用jQuery的attr方法,而应采用原生JavaScript,确保H5页面添加play()方法以启动播放。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、无法播放视频问题

部分手机浏览器,例如UC浏览器,无法播放H5页面的视频,播放视频要么一直转圈加载,要么报-9324,19000错误。

网上的资料大部分都说是video标签的参数配置不对、浏览器版本不兼容、视频需要用H264编码格式,但都不是我们的问题所在。

最后发现问题出在网络协议上,H5页面在部分手机端的浏览器上只能用http或者websocket协议传输视频数据,不能用https协议

解决方案就是在video标签中使用完整的http视频链接,即使用http前缀的绝对路径。

<video src="http://domain/static/video/filename.mp4" ...>

然后我们在服务器的nginx上单独为/static/video目录配置一个http协议的静态资源映射。

二、无法切换视频源问题

H5页面不能使用jquery的attr方法切换视频源,否则点击切换后的视频无法播放,要使用原生js实现切换功能

<video id="videoid" src="http://domain/static/video/filename.mp4"></video>

错误方式:

if (isH5) {
    $("#videoid").attr({"src": "http://" + window.location.host + newVideoSrc});  // H5页面加上http前缀,使用绝对路径
} else {
    $("#videoid").attr({"src": newVideoSrc});
}

正确方式:

let video = document.getElementById("videoid");
if (isH5) {
    video.src = "http://" + window.location.host + newVideoSrc;  // H5页面加上http前缀,使用绝对路径
    video.play();  // H5页面必须加这个自动开始播放,不然切换后无法播放,非H5页面加不加都行
} else {
    video.src = newVideoSrc;
}

注意H5页面要加上video.play();,否则切换后还是无法播放。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值