admin管理员组文章数量:1530518
一、无法播放视频问题
部分手机浏览器,例如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();,否则切换后还是无法播放。
版权声明:本文标题:H5页面在手机浏览器上无法播放视频或无法切换视频源的解决方案 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dianzi/1725798012a1043221.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论