How to Create a Video element using JavaScript

avatar
Borislav Hadzhiev

Last updated: Mar 5, 2024
3 min

banner

# Create a Video element using JavaScript

To create a video element:

  1. Use the document.createElement() method to create the video element.
  2. Set the src attribute on the element to a local or remote video file.
  3. Add the element to the page using the appendChild() method.

Here is the HTML for the examples.

index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> </head> <body> <div id="box"></div> <script src="index.js"></script> </body> </html>
The code for this article is available on GitHub

And here is the related JavaScript code.

index.js
const video = document.createElement('video'); // ๐Ÿ‘‡๏ธ Local file // video.src = 'video.mp4'; // ๐Ÿ‘‡๏ธ Remote file video.src = 'https://archive.org/download/BigBuckBunny_124/Content/big_buck_bunny_720p_surround.mp4'; video.poster = 'https://peach.blender.org/wp-content/uploads/title_anouncement.jpg?x11217'; video.autoplay = false; video.controls = true; video.muted = false; video.height = 240; // ๐Ÿ‘ˆ๏ธ in px video.width = 320; // ๐Ÿ‘ˆ๏ธ in px const box = document.getElementById('box'); box.appendChild(video);

create video element using javascript

The code for this article is available on GitHub

We used the document.createElement() method to create the video element.

The only parameter we passed to the method is the type of element to be created (video in the example).

The createElement method returns the newly created element.

We set the element's src attribute to a remotely hosted video file.

However, if you have a video on the local file system, you can set the src attribute to the path pointing to the video.

Not all browsers support the same video formats, so you can check if the user's browser supports the format before setting the element's src attribute.

index.js
const video = document.createElement('video'); video.poster = 'https://peach.blender.org/wp-content/uploads/title_anouncement.jpg?x11217'; video.autoplay = false; video.controls = true; video.muted = false; video.height = 240; // ๐Ÿ‘ˆ๏ธ in px video.width = 320; // ๐Ÿ‘ˆ๏ธ in px if (video.canPlayType('video/mp4')) { console.log('set src to mp4 video'); video.src = 'my-video.mp4' } else if (video.canPlayType('video/ogg')) { console.log('set src to ogg video'); video.src = 'my-video.ogg' } else { console.log('provide link to user'); } const box = document.getElementById('box'); box.appendChild(video);
The code for this article is available on GitHub

The video element supports many attributes.

These are the attributes we used:

  • poster - a URL for an image to be shown while the video is downloading.

  • autoplay - whether the video should automatically start playing as soon as it can do so without stopping to finish loading the data

  • controls - allows the user to control video playback, e.g. volume, pause and resume the video.

  • muted - indicates if the video should be muted by default.

  • height and width - can be set to numbers and represent the height and width of the video's display area in pixels

There are many more attributes you might need to set depending on your use case, for a complete list, check out the MDN video docs.

If I load the page from the example above, I can see that the video element was created successfully.

video created successfully

The last step is to use the Node.appendChild() method to add the video element to the end of the list of the div's children.

Notice that we used the HTMLMediaElement.canPlayType() method in the example.

index.js
const video = document.createElement('video'); video.poster = 'https://peach.blender.org/wp-content/uploads/title_anouncement.jpg?x11217'; video.autoplay = false; video.controls = true; video.muted = false; video.height = 240; // ๐Ÿ‘ˆ๏ธ in px video.width = 320; // ๐Ÿ‘ˆ๏ธ in px if (video.canPlayType('video/mp4')) { console.log('set src to mp4 video'); video.src = 'my-video.mp4' } else if (video.canPlayType('video/ogg')) { console.log('set src to ogg video'); video.src = 'my-video.ogg' } else { console.log('provide link to user'); } const box = document.getElementById('box'); box.appendChild(video);
The code for this article is available on GitHub

The method returns a string that indicates how likely it is that the media can be played.

The canPlayType() method returns a string that has 3 possible values:

  • "" (empty string) - the media cannot be played on the current device
  • "probably" - the media is probably playable on the current device
  • "maybe" - there is not enough information to determine whether the media can play on the current device

# Additional Resources

You can learn more about the related topics by checking out the following tutorials:

I wrote a book in which I share everything I know about how to become a better, more efficient programmer.
book cover
You can use the search field on my Home Page to filter through all of my articles.

Copyright ยฉ 2025 Borislav Hadzhiev