Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

Custom elements (web components) for making audio and video player controls that look great in your website or app.

License

NotificationsYou must be signed in to change notification settings

muxinc/media-chrome

Repository files navigation

Media Chrome Logo

NPM VersionNPM DownloadsjsDelivr hits (npm)npm bundle sizeslack

Your media player's dancing suit. 🕺

Fully customizable media player controls using web components (native custom elements).

  • Compatible with any javascript framework (React, Angular, Svelte, etc.)
  • Compatible with the<video> and<audio> elements anda lot of players (YouTube, HLS.js, and more)
  • Simple HTML to add/remove controls
  • Simple CSS to style the controls

FromMux and the creator ofVideo.js.

Documentation

Visit theofficial documentation for Media Chrome for the latest up-to-date usage instructions.

You can find thedocumentation for v0.x of media-chrome here.

Examples

See all of the repo examples in action.

Video Example

<scripttype="module"src="https://cdn.jsdelivr.net/npm/media-chrome@4/+esm"></script><media-controller><videoslot="media"src="https://stream.mux.com/DS00Spx1CV902MCtPj5WknGlR102V5HFkDe/high.mp4"crossorigin><tracklabel="thumbnails"defaultkind="metadata"src="https://image.mux.com/DS00Spx1CV902MCtPj5WknGlR102V5HFkDe/storyboard.vtt"/></video><media-control-bar><media-play-button></media-play-button><media-mute-button></media-mute-button><media-volume-range></media-volume-range><media-time-range></media-time-range><media-pip-button></media-pip-button><media-fullscreen-button></media-fullscreen-button></media-control-bar></media-controller>
Media Chrome Video Player Demo

Audio Example

<scripttype="module"src="https://cdn.jsdelivr.net/npm/media-chrome@4/+esm"></script><media-controlleraudio><audioslot="media"src="https://stream.mux.com/O4h5z00885HEucNNa1rV02wZapcGp01FXXoJd35AHmGX7g/audio.m4a"></audio><media-control-bar><media-play-button></media-play-button><media-time-displayshowduration></media-time-display><media-time-range></media-time-range><media-playback-rate-button></media-playback-rate-button><media-mute-button></media-mute-button><media-volume-range></media-volume-range></media-control-bar></media-controller>
Media Chrome Audio Player Demo

Use with React

While you technically can use Media Chrome elements directly with React, it can sometimes be a bit clunky to work with Web Components in React, and some things just don't feel idiomatic to the framework (for example: having to useclass= instead ofclassName=, seeReact's official docs regarding web components for more details). To help with this, we've published some React wrapper components for all of our core Elements. You can read up on using themhere.

Why?

More often than not web designers and developers just use the default media player controls, even when creating a beautiful custom design theme. It's hard not to.

  • Web browsers have built-in media controls that can't easily be customized and look different in every browser.
  • Social sites like Youtube, Vimeo, and SoundCloud only let you customize small details of the player, like primary button color.
  • Media controls are complex and hard to build from scratch. Open source players like Video.js and JW Player help, but require you to learn proprietary JS APIs, and can be difficult to use with popular Javascript frameworks.

It should be easier...<media-chrome> is an attempt at solving that.

Why now?

Web components. @heff spoke aboutthe potential of web components for video at Demuxed 2015, andagain in 2020. They allow us to extend the browser's base HTML functionality, meaning we can now build media player controls as simple HTML tags that:

  • Can be used like any native HTML tag in HTML, Javascript, and CSS (unleash your designer)
  • Are compatible by default with Javascript frameworks (React, Angular, Svelte)
  • Can be used across players when using multiple in the same site, e.g Youtube &<video>. (Could even be used by players as their own built-in controls)

Core Concepts


[8]ページ先頭

©2009-2025 Movatter.jp