中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

html5的video標簽不能播放如何解決

發布時間:2023-01-29 09:44:52 來源:億速云 閱讀:540 作者:iii 欄目:web開發

這篇“html5的video標簽不能播放如何解決”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“html5的video標簽不能播放如何解決”文章吧。

html5的video標簽不能播放的解決辦法:1、使用視頻截圖做一個播放按鈕,占位視頻原有位置;2、監聽占位按鈕的click事件,使用“video.play()”;3、把占位圖和loading隱藏即可。

IOS-HTML5-Video標簽不能播放

h6的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', 'h6');
                            _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>

以上就是關于“html5的video標簽不能播放如何解決”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蒙城县| 邻水| 同心县| 杭锦旗| 利津县| 蓬溪县| 南和县| 蒲城县| 利川市| 秭归县| 三河市| 涪陵区| 鄂托克前旗| 朔州市| 湘乡市| 景洪市| 永胜县| 淮滨县| 黔东| 新昌县| 仪陇县| 静宁县| 乐亭县| 涿鹿县| 玉龙| 白河县| 乐昌市| 乐陵市| 锡林浩特市| 龙游县| 阿克| 桃源县| 崇明县| 乌海市| 砚山县| 九江市| 甘肃省| 大厂| 安乡县| 瓦房店市| 桂林市|