广告
返回顶部
首页 > 资讯 > 前端开发 > 其他 >html5的video标签不能播放怎么办
  • 253
分享到

html5的video标签不能播放怎么办

videohtml5 2023-05-14 22:05:58 253人浏览 薄情痞子
摘要

本教程操作环境:windows10系统、HTML5版、DELL G3电脑html5的video标签不能播放怎么办?IOS-HTML5-Video标签不能播放h5的video标签 在UIWEBview中无法播放,Safari可以,某些手机可以

html5的video标签不能播放怎么办

教程操作环境:windows10系统、HTML5版、DELL G3电脑

html5的video标签不能播放怎么办?

IOS-HTML5-Video标签不能播放

h5的video标签 在UIWEBview中无法播放,Safari可以,

某些手机可以某些手机不行

和video.js实现一致,不嫌弃再引一个兼容包,想有更好体验的

建议使用https://videojs.com/

想自己体验一把原理,可以在文章最后拷贝demo代码运行

传统的方法在html中写video标签就可以点击播放啦

<video src="xxx.mp4" controls poster="url?vframe/jpg/offset/5" preload="load"></video>
// ?vframe/jpg/offset/5  这个是七牛接口,取截图用的,5就是第5秒截图

BUT,这么写在iOS 10.3.2/3 11.x.x. iphone 6/6p 7等等几个测试机中就不行,但是在个人手机上又可以,有的手机可以有的手机不行。

修改后:

步骤1:使用视频截图再做一个播放按钮,占位视频原有位置

步骤2: 监听占位按钮的click事件,使用video.play(),就可以看到视频有请求在加载了

步骤3: 在加载中的视频都有一个promise可以拿到,then以后把占位图和loading隐藏就可以了

tips:

  • 不同手机/系统会有不同的请求范围,一般都是分割成3-5个206请求。

  • console.time("加载毫秒");可以看到加载时间,基本和Charles抓包看到的一致。

  • 不同手机/系统也会有不同的then表现有的是一点就给返回,有的是需要等视频全部加载完才返回

  • 视频DOM的属性可以拿到当前加载了多少,总量是多少,除一下就是百分比,具体属性可以看 > Https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/video

线上地址:http://m.soyoung.com/item/detail?type=0&sys=3&item_id=263&cityId=0

demo代码(方便有些朋友,私信想直接拿走demo啦~)

<!DOCTYPE html>
<html data-dpr="1" style="font-size: 55px;">
    <head>
        <meta charset="utf-8"/><meta http-equiv="x-ua-compatible" content="IE=edge,chrome=1"/>
        <title>视频DEMO</title>
    </head>
    <body style="font-size: 24px;">
        <style>
            html,body,video{
                margin: 0;
                padding: 0;
            }
            .pub-swipe .media {
                position: relative;
                font-size: 0;
                margin-bottom: 0.4rem;
            }
            .pub-swipe .media img,
            .pub-swipe .media video {
                display: block;
                margin: 0 auto;
                width: 100%;
                min-height: 4.667rem;
            }
            .pub-swipe .desc,
            .pub-swipe .media img {
                margin-bottom: 0.267rem;
            }
            .pub-swipe .media video {
                width: 100%;
                height: 4.667rem;
            }
            .pub-swipe .media img.video-Go {
                width: 2.707rem;
                height: 2.707rem;
                min-height: 0;
                position: absolute;
                left: 50%;
                margin-left: -.853rem;
                top: 1.3rem;
                z-index: 5;
            }
            .hide {
                display: none !important;
            }
        </style>
        <div class="pub-swipe">
            <p class="media">
                <i class="video-i" data-src="http://videosy.soyoung.com/item-263.MP4">
                    <img src="http://videosy.soyoung.com/item-263.MP4?vframe/jpg/offset/5"/>
                    <img class="video-go" src="https://mstatic.soyoung.com/m/static/img/product/video_go.png"/>
                </i>
            </p>
        </div>
        <script>
            
            var isIPhone = window.navigator.appVersion.match(/iphone/gi);
            var creat_video = function () {
                var _video = document.getElementsByClassName('video-i');
                if (_video.length > 0) {
                    for (var i = 0; i < _video.length; i++) {
                        var _that = _video[i];
                        _that.addEventListener('click', function (e) {
                            var _this = e.currentTarget,
                                _videoUrl = _this.getAttribute('data-src'),
                                _img = _this.children[0].getAttribute('src'),
                                _dom = document.createElement('video'),
                                _autoPlayAllowed = true,
                                _loading = document.createElement('div'),
                                _p,
                                _process = document.createElement('i');
                            _noSound = document.createElement('em');
                            if (_this.getAttribute('data-video')) {
                                var _video = _this.parentnode.querySelectorAll('video');
                                var _noSound = _this.parentNode.querySelectorAll('.no-sound');
                                if (_video.length > 0) {
                                    _dom = _video[0];
                                    // if (_dom.ended) {
                                    if (isIPhone) {
                                        //修改Ios11状态不准,视频无法播放的问题
                                        if (_dom.src.indexOf('random') > -1) {
                                            _dom.src = _dom.src.split('random=')[0] + 'random=' + _dom.src.split('random=')[1] + 1;
                                        } else {
                                            _dom.src = _dom.src + '?random=' + Math.floor(Math.random() * (100 - 10 + 1) + 10);
                                        }
                                    }
                                    _noSound[0].classList.remove('hide');
                                    _dom.play();
                                    _this.classList.add('hide');
                                    _dom.classList.remove('hide');
                                    // }
                                }
                                return;
                            }
                            _this.setAttribute('data-video', '1');
                            _process.setAttribute('class', 'vjs-process');
                            _process.innerHTML = '加载中...';
                            _loading.setAttribute('class', 'vjs-loading-spinner');
                            _dom.setAttribute('src', _videoUrl);
                            _dom.setAttribute('controls', 'controls');
                            _dom.setAttribute('autoPlay', 'false');
                            // _dom.setAttribute('x5-video-player-type', 'h5');
                            _this.parentNode.appendChild(_loading);
                            _this.parentNode.appendChild(_process);
                            _this.parentNode.classList.add('vjs-waiting');
                            _noSound.setAttribute('class', 'no-sound');
                            _noSound.innerHTML = '无声';
                            // _dom.setAttribute('webkit-playsinline', 'webkit-playsinline');
                            // _dom.setAttribute('playsinline', 'playsinline');
                            _dom.setAttribute('poster', _img);
                            _p = _dom.play();
                            console.time("加载毫秒");
                            var _dom_buffered_promise = function () {
                                var _end = _dom.buffered.end(0);
                                var _duration = _dom.duration;
                                var _a = Math.round(_end / _duration * 100);
                                _process.innerHTML = _a + '%';
                                console.log(_end + ' ' + _duration)
                                if (_a < 10) {
                                    setTimeout(_dom_buffered, 200);
                                } else {
                                    _dom_buffered();
                                }
                            };
                            var _dom_buffered = function () {
                                _this.parentNode.classList.remove('vjs-waiting');
                                _this.classList.add('hide');
                                _process.classList.add('hide');
                                _this.parentNode.appendChild(_dom);
                                _this.parentNode.appendChild(_noSound);
                                _dom.addEventListener('ended', function () {
                                    _dom.classList.add('hide');
                                    _this.classList.remove('hide');
                                    _noSound.classList.add('hide');
                                });
                                _dom.currentTime = 0;
                                console.timeEnd("加载毫秒");
                            };
                            if (_p instanceof Promise) {
                                _p.catch(function (error) {
                                    console.log(error.message);
                                    if (error.name === 'NotAllowedError') {
                                        _autoPlayAllowed = false;
                                    }
                                }).then(function (e) {
                                    if (_autoPlayAllowed) {
                                        _dom_buffered_promise();
                                    }
                                });
                            } else {
                                //ios8-9拿不到promise需要给个延时处理
                                setTimeout(function () {
                                    _dom_buffered();
                                }, 4000);
                            }
                        });
                    }
                }
            };
            new creat_video();
        </script>
    </body>
</html>

b8b4995222327274ed1c2070eed4542.jpg

以上就是html5的video标签不能播放怎么办的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: html5的video标签不能播放怎么办

本文链接: https://www.lsjlt.com/news/206874.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • html5的video标签不能播放怎么办
    本教程操作环境:Windows10系统、HTML5版、DELL G3电脑html5的video标签不能播放怎么办?IOS-HTML5-Video标签不能播放h5的video标签 在UIwebview中无法播放,Safari可以,某些手机可以...
    99+
    2023-05-14
    video html5
  • html5中video标签无法播放mp4怎么办
    这篇文章给大家分享的是有关html5中video标签无法播放mp4怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。问题分析手机录制的视频属性: 格式化工厂转码的视频...
    99+
    2022-10-19
  • html5的video标签不能播放如何解决
    这篇“html5的video标签不能播放如何解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“html5的video标签不能...
    99+
    2023-07-05
  • HTML5中Video标签有部分MP4无法播放怎么办
    这篇文章主要为大家展示了“HTML5中Video标签有部分MP4无法播放怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“HTML5中Video标签有部分MP...
    99+
    2022-10-19
  • html5中video标签不能播放视频的示例分析
    小编给大家分享一下html5中video标签不能播放视频的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   在页面中...
    99+
    2022-10-19
  • uniapp苹果不能播放video怎么办
    最近,你是否遇到了使用uniapp开发的iOS应用程序播放视频的问题?若是,则需要仔细阅读本文。uniapp是一款基于Vue.js框架的开源跨平台应用程序开发框架。它能够快速开发出支持多个平台的应用程序,包括iOS和Android。然而,一...
    99+
    2023-05-14
  • HTML5 video标签播放控制的技巧有哪些
    这篇文章主要介绍“HTML5 video标签播放控制的技巧有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“HTML5 video标签播放控制的技巧有哪些”文章能...
    99+
    2022-10-19
  • 怎么在html5中自定义video标签实现海报与播放按钮功能
    怎么在html5中自定义video标签实现海报与播放按钮功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、问题默认播放按键不好看设置自定义封面图以上这两点都...
    99+
    2023-06-09
  • HTML5的Video标签怎么用
    这篇文章主要介绍HTML5的Video标签怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! <video>标签的属性 复制代码 代码如下: src :视频的属...
    99+
    2022-10-19
  • HTML5的video标签怎么使用
    要使用HTML5的video标签,可以按照以下步骤进行操作:1. 首先,在HTML文档中添加video标签,如下所示:```html...
    99+
    2023-09-13
    HTML5
  • HTML5的audio标签和video标签怎么使用
    这篇文章主要介绍了HTML5的audio标签和video标签怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇HTML5的audio标签和video标签怎么使用文章都会有所...
    99+
    2022-10-19
  • 怎么解决html5中的video标签ios系统中无法播放使用的问题
    这篇文章主要介绍怎么解决html5中的video标签ios系统中无法播放使用的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!先是从前端的角度去考虑,如何让safari浏览器兼容video,并支持播放(未找到解决的...
    99+
    2023-06-09
  • php视频不能播放怎么办
    本教程操作环境:windows7系统、PHP8.1版、Dell G3电脑。php视频不能播放怎么办?问题描述:php调用scp上传视频文件无法播放?使用PHP调用scp上传视频文件到目标服务器,上传之后无法播放,原视频文件可以正常播放。代码...
    99+
    2022-11-13
  • ubuntu21.04不能播播放rmvb文件怎么办?ubuntu播放rmvb视频的技巧
    今天在ubuntu21.04中播放一个rmvb格式的视频,发现打开后是黑屏并没有办法播放,后来发现是因为默认的视频播放器不支持rmvb视频,需要我们自己去安装对应解码的工具,该怎么安装并播放rmvb格式的视频呢》下面我们就来看...
    99+
    2022-06-06
    ubuntu rmvb视频
  • html5 音乐播放器 audio 标签使用是怎样的
    html5 音乐播放器 audio 标签使用是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 代码如下:...
    99+
    2022-10-19
  • Win7电脑不能播放视频怎么办
    如果Win7电脑无法播放视频,可以尝试以下方法解决:1. 检查视频文件是否损坏:尝试播放其他视频文件,或者将该视频文件转移到其他设备...
    99+
    2023-09-17
    win7
  • vue中怎么使用h5 video标签实现弹窗播放本地视频
    这篇“vue中怎么使用h5 video标签实现弹窗播放本地视频”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue...
    99+
    2023-06-30
  • HTML5中audio在手机端和微信端不能自动播放怎么办
    小编给大家分享一下HTML5中audio在手机端和微信端不能自动播放怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!再做H5页面的时候,发现audio在手机端和微信端添加了autopl...
    99+
    2022-10-19
  • 怎么关闭Win7的自动播放功能让Win7不自动播放文件
    在Win7中为了让用户的使用更加的方便,因而在系统中也是加入了一个自动播放的功能,这个功能的最大特点就是可以自动的播放用户存放在磁盘中的多媒体视频文件,这个功能非常的方便了我们的生活,让我们可以更加轻松的欣赏电影,不过这...
    99+
    2023-06-05
    Win7 自动播放 文件 功能
  • Win8系统下QQ弹出消息时播放器声音变小怎么办?播放器声音不受影响的解决办法
    播放器声音不受影响的解决办法:  1、如果大家比较熟悉Windows传统桌面的操作的话,可以返回到Win8电脑的传统桌面位置,在桌面的右下角找到声音图标,右键点击声音图标,然后选择下滑...
    99+
    2022-06-04
    播放器 声音 不受
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作