it-swarm.com.ru

Воспроизвести / приостановить видео HTML 5 с помощью JQuery

Я пытаюсь контролировать HTML5 видео с помощью JQuery. У меня есть два клипа в интерфейсе с вкладками, всего шесть вкладок, на других просто есть изображения. Я пытаюсь заставить воспроизводиться видеоклипы при нажатии на их вкладку, а затем останавливаться при нажатии любой из других.

Это должно быть простым делом, но я не могу заставить его работать, код, который я использую для воспроизведения видео:

$('#playMovie1').click(function(){
  $('#movie1').play();
      });

Я читал, что элемент видео должен быть выставлен в функции, чтобы иметь возможность управлять им, но не могу найти пример. Я могу заставить его работать с помощью JS:

document.getElementById('movie1').play();

Будем признательны любому совету. Спасибо

183
Barny83

Ваше решение показывает проблему здесь - play - это не функция jQuery, а функция элемента DOM. Поэтому вам нужно вызвать его для элемента DOM. Вы привели пример того, как это сделать с помощью встроенных функций DOM. Эквивалентом jQuery - если вы хотите сделать это, чтобы соответствовать существующему выбору jQuery - было бы $('#videoId').get(0).play(). ( get получает собственный элемент DOM из выбора jQuery.)

321
lonesomeday

Вот как мне удалось заставить его работать:

jQuery( document ).ready(function($) {
    $('.myHTMLvideo').click(function() {
        this.paused ? this.play() : this.pause();
    });
});

Все мои теги HTML5 имеют класс "myHTMLvideo"

53
Miguel Tavares

Ты можешь сделать

$('video').trigger('play');
$('video').trigger('pause');
45
wonder

Зачем вам нужно использовать JQuery? Предлагаемое вами решение работает, и оно, вероятно, быстрее, чем создание объекта jQuery.

document.getElementById('videoId').play();
20
sudo work

Для паузы нескольких видео я обнаружил, что это работает хорошо:

$("video").each(function(){
    $(this).get(0).pause();
});

Это может быть помещено в функцию щелчка, которая довольно удобна.

19
Josh Holmes

В качестве продолжения ответа одного дня, вы также можете использовать

$('#playMovie1').click(function(){
    $('#movie1')[0].play();
});

Обратите внимание, что не вызывается функция jQuery get () или eq (). Массив DOM, используемый для вызова функции play (). Это короткий путь, чтобы иметь в виду.

13
ozanmuyes

Мне нравится этот:

$('video').click(function(){
    this[this.paused ? 'play' : 'pause']();
});

Надеюсь, поможет.

10
user4227915

Я использую FancyBox и jQuery для встраивания видео. Дайте ему удостоверение личности.

Возможно, не ЛУЧШЕЕ решение могло бы переключить воспроизведение/паузу по-другому - но легко для меня и ЭТО РАБОТАЕТ! :)

В

`

<input type="hidden" id="current_video_playing">

<input type="hidden" id="current_video_status" value="playing">

<video id="video-1523" autobuffer="false" src="movie.mp4"></video>

<script>

// Play Pause with spacebar

$(document).keypress(function(e) { 

    theVideo = document.getElementById('current_video_playing').value

    if (e.which == 32) {

        if (document.getElementById('current_video_status').value == 'playing') {

            document.getElementById(theVideo).pause();

            document.getElementById('current_video_status').value = 'paused'

        } else {

            document.getElementById('current_video_status').value = 'playing'

            document.getElementById(theVideo).play();

        }

    }

});

</script>`
4
Alexander W

Это простые методы, которые мы можем использовать

на JQuery функцию нажатия кнопки

$("#button").click(function(event){
    $('video').trigger('play');
    $('video').trigger('pause');
}

Спасибо

2
subindas pm

Просто отметьте, что вы проверяете, поддерживает ли браузер функцию видео, прежде чем пытаться вызвать ее:

if($('#movie1')[0].play)
    $('#movie1')[0].play();

Это предотвратит ошибки JavaScript в браузерах, которые не поддерживают тег видео.

1
Alex W

По JQuery с использованием селекторов

$("video_selector").trigger('play');  
$("video_selector").trigger('pause');
$("div.video:first").trigger('play');$("div.video:first").trigger('pause');
$("#video_ID").trigger('play');$("#video_ID").trigger('pause');

По Javascript с использованием идентификатора

video_ID.play();  video_ID.pause();

OR

document.getElementById('video_ID').play();  document.getElementById('video_ID').pause();
1
user1570636
    enter code here
<form class="md-form" action="#">
  <div class="file-field">
    <div class="btn btn-primary btn-sm float-left">
      <span>Choose files</span>
      <input type="file" multiple>
    </div>
    <div class="file-path-wrapper">
      <input class="file-path validate" type="text" placeholder="Upload one or more files">
    </div>
  </div>
</form>

<video  width="320" height="240" id="keerthan"></video>

<button onclick="playVid()" type="button">Play Video</button>
<button onclick="pauseVid()" type="button">Pause Video</button> 
<script>
    (function localFileVideoPlayer() {

  var playSelectedFile = function (event) {
    var file = this.files[0]
    var type = file.type
    var videoNode = document.querySelector('video')




    var fileURL = URL.createObjectURL(file)
    videoNode.src = fileURL
  }
  var inputNode = document.querySelector('input')
  inputNode.addEventListener('change', playSelectedFile, false)
})()
function playVid() { 
  keerthan.play(); 
} 

function pauseVid() { 
  keerthan.pause(); 
} 

</script>
0
KEERTHAN K C
<video style="min-width: 100%; min-height: 100%; " id="vid" width="auto" height="auto" controls autoplay="true" loop="loop" preload="auto" muted="muted">
<source src="video/sample.mp4" type="video/mp4">
<source src="video/sample.ogg" type="video/ogg">
</video>
<script> 
$(document).ready(function(){
document.getElementById('vid').play(); });
</script> 
0
Anusuya

Я также заставил это работать так:

$(window).scroll(function() {
    if($(window).scrollTop() > 0)
        document.querySelector('#video').pause();
    else
        document.querySelector('#video').play();
});
0
Jasper Chang

используйте это .. $('#video1').attr({'autoplay':'true'});

0
Antares500

@loneSomeday объяснил это красиво, вот одно решение, которое также может дать вам хорошее представление о том, как добиться функциональности воспроизведения/паузы

воспроизведение/пауза видео при нажатии

0
sheelpriy