需求:使用uniapp的video组件 制作视频播放,需要切换手动视频或播完一集后自动播放
问题:即使使用了 hls插件 ,也有部分机型不能自动播放,由于浏览器限制,视频不能自动播放,需要用户手动触发才可以
解决:通过微信浏览器提供的 WeixinJSBridgeReady 做桥接后就可以绕过这一限制
if (window.WeixinJSBridge) {
WeixinJSBridge.invoke('getNetworkType', {}, function (e) {
video.play();
})
} else {
document.addEventListener("WeixinJSBridgeReady", function() {
WeixinJSBridge.invoke('getNetworkType', {}, function (e) {
video.play();
})
})
}
附m3u8视频播放处理,外面套一层函数,传url进来
this.$nextTick(() => {
if (url.includes('.m3u8')) {
const video = document.querySelector('#myVideo video');
if (Hls.isSupported()) {
this.hlsjs.loadSource(url);//设置播放路径
this.hlsjs.attachMedia(video);//解析到video标签上
this.hlsjs.on(Hls.Events.MANIFEST_PARSED, (e) => {
video.play();
console