текущее / длительность видео html5? - PullRequest
40 голосов
/ 17 июня 2011

Мне нужен способ узнать общую длительность видео и текущее время с помощью jquery и отобразить его в виде пары тегов

.
<div id="current">0:00</div>
<div id="duration">0:00</div>

Я искал весь деньи я знаю, как получить их, я просто не могу их отобразить. # jquerynoob

Ответы [ 5 ]

51 голосов
/ 26 марта 2013

HTML:

<video
    id="video-active"
    class="video-active"
    width="640"
    height="390"
    controls="controls">
    <source src="myvideo.mp4" type="video/mp4">
</video>
<div id="current">0:00</div>
<div id="duration">0:00</div>

JavaScript:

$(document).ready(function(){
  $("#video-active").on(
    "timeupdate", 
    function(event){
      onTrackedVideoFrame(this.currentTime, this.duration);
    });
});

function onTrackedVideoFrame(currentTime, duration){
    $("#current").text(currentTime); //Change #current to currentTime
    $("#duration").text(duration)
}

Примечания:

Каждые 15–250 мс или всякий раз, когда изменяется положение медиа-контроллера MediaController, в зависимости от того, что происходит реже, пользовательский агент должен поставить задачу в очередь для запуска простого события timeupdate в MediaController.

http://www.w3.org/TR/html5/embedded-content-0.html#media-controller-position

18 голосов
/ 17 июня 2011

Эта страница может вам помочь. Все, что вам нужно знать о видео и аудио HTML5

var video = document.createElement('video');
var curtime = video.currentTime;

Если у вас уже есть элемент video, должен работать .currentTime. Если вам нужна дополнительная информация, эта веб-страница должна помочь.

13 голосов
/ 06 декабря 2012

Рабочий пример здесь: http://jsfiddle.net/tQ2CZ/1/

HTML

<div id="video_container">
<video poster="http://media.w3.org/2010/05/sintel/poster.png" preload="none" controls="" id="video" tabindex="0">
    <source type="video/mp4" src="http://media.w3.org/2010/05/sintel/trailer.mp4" id="mp4"></source>
    <source type="video/webm" src="http://media.w3.org/2010/05/sintel/trailer.webm" id="webm"></source>
    <source type="video/ogg" src="http://media.w3.org/2010/05/sintel/trailer.ogv" id="ogv"></source>
    <p>Your user agent does not support the HTML5 Video element.</p>
</video>
</div>

<div>Current Time : <span  id="currentTime">0</span></div>
<div>Total time : <span id="totalTime">0</span></div>

JS

$(function(){
$('#currentTime').html($('#video_container').find('video').get(0).load());
$('#currentTime').html($('#video_container').find('video').get(0).play());
})
setInterval(function(){
$('#currentTime').html($('#video_container').find('video').get(0).currentTime);
$('#totalTime').html($('#video_container').find('video').get(0).duration);    
},500)
2 голосов
/ 17 июня 2011

Я предполагаю, что вы хотите отобразить это как часть проигрывателя.

Этот сайт описывает, как получить текущее и общее время независимо от того, как вы хотите отобразить его, используя jQuery:

http://dev.opera.com/articles/view/custom-html5-video-player-with-css3-and-jquery/

Это также расскажет, как установить его для определенного div. Как уже упоминал Филипп, .currentTime покажет вам, где вы находитесь в видео.

1 голос
/ 04 марта 2017

https://www.w3schools.com/tags/av_event_timeupdate.asp

// Get the <video> element with id="myVideo"
var vid = document.getElementById("myVideo");

// Assign an ontimeupdate event to the <video> element, and execute a function if the current playback position has changed
vid.ontimeupdate = function() {myFunction()};

function myFunction() {
// Display the current position of the video in a <p> element with id="demo"
    document.getElementById("demo").innerHTML = vid.currentTime;
}
...