Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

HTML Audio/Video DOM canplaythrough Event

❮ HTML Audio/Video DOM Reference

Example

Alert that the video can be played all the way through, without stopping:

let vid = document.getElementById("myVideo");
vid.oncanplaythrough = function() {
    alert("Can play through video without stopping");
};
Try it Yourself »

More "Try it Yourself" examples below.


Definition and Usage

The canplaythrough event occurs when the browser estimates it can play through the specified audio/video without having to stop for buffering.

During the loading process of an audio/video, the following events occur, in this order:

  1. loadstart
  2. durationchange
  3. loadedmetadata
  4. loadeddata
  5. progress
  6. canplay
  7. canplaythrough

Browser Support

The numbers in the table specify the first browser version that fully supports the event.

Event
canplaythrough Yes 9.0 Yes Yes Yes

Syntax

In HTML:

<audio|video oncanplaythrough="myScript">Try it

In JavaScript:

audio|video.oncanplaythrough=function(){myScript};Try it

In JavaScript, using the addEventListener() method:

audio|video.addEventListener("canplaythrough", myScript);Try it

Technical Details

Supported HTML tags: <audio> and <video>
Supported JavaScript objects: Audio, Video

More Examples

Example

Alert that the audio can be played all the way through, without stopping:

let aud = document.getElementById("myAudio");
aud.oncanplaythrough = function() {
    alert("Can play through audio without stopping");
};
Try it Yourself »

❮ HTML Audio/Video DOM Reference
×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2025 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.