The timeupdate
event is fired when the time indicated by the currentTime
attribute has been updated.
The event frequency is dependent on the system load, but will be thrown between about 4Hz and 66Hz (assuming the event handlers don't take longer than 250ms to run). User agents are encouraged to vary the frequency of the event based on the system load and the average cost of processing the event each time, so that the UI updates are not any more frequent than the user agent can comfortably handle while decoding the video.
This event is not cancelable and does not bubble.
Use the event name in methods like addEventListener()
, or set an event handler property.
addEventListener("timeupdate", (event) => {});
ontimeupdate = (event) => {};
These examples add an event listener for the HTMLMediaElement's timeupdate
event, then post a message when that event handler has reacted to the event firing. Remember, the event frequency is dependent on the system load.
Using addEventListener()
:
const video = document.querySelector("video");
video.addEventListener("timeupdate", (event) => {
console.log("The currentTime attribute has been updated. Again.");
});
Using the ontimeupdate
event handler property:
const video = document.querySelector("video");
video.ontimeupdate = (event) => {
console.log("The currentTime attribute has been updated. Again.");
};