<hls-video>
https://github.com/muxinc/media-elements/tree/main/packages/hls-video-element
A custom element for playing HTTP Live Streaming (HLS) videos.
<media-controller>
<hls-video
src="https://stream.mux.com/A3VXy02VoUinw01pwyomEO3bHnG4P32xzV7u1j1FSzjNg.m3u8"
slot="media"
crossorigin
muted
></hls-video>
<media-loading-indicator slot="centered-chrome" noautohide></media-loading-indicator>
<media-control-bar>
<media-play-button></media-play-button>
<media-seek-backward-button></media-seek-backward-button>
<media-seek-forward-button ></media-seek-forward-button>
<media-mute-button></media-mute-button>
<media-volume-range></media-volume-range>
<media-time-range></media-time-range>
<media-time-display showduration remaining></media-time-display>
<media-playback-rate-button></media-playback-rate-button>
<media-fullscreen-button></media-fullscreen-button>
</media-control-bar>
</media-controller>
First install the NPM package:
npm install hls-video-element
Import in your app javascript (e.g. src/App.js):
import 'hls-video-element';
Optionally, you can load the script directly from a CDN using
jsDelivr:
<script type="module" src="https://cdn.jsdelivr.net/npm/hls-video-element@1.2/+esm"></script>
This will register the custom elements with the browser so they can be used as HTML.