Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Muted video fails to autoplay when inserted into HTML via Javascript

I am trying to insert a HTML5 <video> element through Javascript, but it fails to autoplay despite it being muted.

Background Context

I would like to transfer all of my gif assets over to mp4 format. Likewise, I would like to have the HTML video emulate a gif. It should include the following properties:

  • Be muted
  • Autoplays as soon as the webpage loads
  • Loop indefinitely
  • Plays in line

I am currently on Chrome 100.

What I've Tried

Relevant code is held within this codepen. I want to add the HTML video dynamically through javascript. But this fails to autoplay even though both autoplay and muted attributes are specified.

However, if I have the video element with the same attributes directly written within the HTML, the autoplay functionality works just fine.


How do I insert the video with JS and get it to autoplay?

like image 847
kinda_raffy Avatar asked Oct 31 '25 04:10

kinda_raffy


1 Answers

I think you could rather set attributes like this :

const anchor = document.querySelector('#anchor');
const vid = document.createElement('video');
anchor.appendChild(vid);
vid.autoplay = true;
vid.loop = true;
vid.muted = true;
vid.playsinline = true;
vid.src = 'https://www.w3schools.com/html/mov_bbb.mp4';

Try to make these modifications. If it still not working, you could add this inline after above code :

vid.play()
like image 102
Théo Champion Avatar answered Nov 01 '25 19:11

Théo Champion



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!