The HTMLMediaElement
interface adds to HTMLElement
the properties and methods needed to support basic media-related capabilities that are common to audio and video. The HTMLVideoElement
and HTMLAudioElement
elements both inherit this interface.
<div id="interfaceDiagram" style="display: inline-block; position: relative; width: 100%; padding-bottom: 20%; vertical-align: middle; overflow: hidden;"><svg style="display: inline-block; position: absolute; top: 0; left: 0;" viewbox="-50 0 600 120" preserveAspectRatio="xMinYMin meet"><a xlink:href="https://developer.mozilla.org/en-US/docs/Web/API/EventTarget" target="_top"><rect x="1" y="1" width="110" height="50" fill="#fff" stroke="#D4DDE4" stroke-width="2px" /><text x="56" y="30" font-size="12px" font-family="Consolas,Monaco,Andale Mono,monospace" fill="#4D4E53" text-anchor="middle" alignment-baseline="middle">EventTarget</text></a><polyline points="111,25 121,20 121,30 111,25" stroke="#D4DDE4" fill="none"/><line x1="121" y1="25" x2="151" y2="25" stroke="#D4DDE4"/><a xlink:href="https://developer.mozilla.org/en-US/docs/Web/API/Node" target="_top"><rect x="151" y="1" width="75" height="50" fill="#fff" stroke="#D4DDE4" stroke-width="2px" /><text x="188.5" y="30" font-size="12px" font-family="Consolas,Monaco,Andale Mono,monospace" fill="#4D4E53" text-anchor="middle" alignment-baseline="middle">Node</text></a><polyline points="226,25 236,20 236,30 226,25" stroke="#D4DDE4" fill="none"/><line x1="236" y1="25" x2="266" y2="25" stroke="#D4DDE4"/><a xlink:href="https://developer.mozilla.org/en-US/docs/Web/API/Element" target="_top"><rect x="266" y="1" width="75" height="50" fill="#fff" stroke="#D4DDE4" stroke-width="2px" /><text x="303.5" y="30" font-size="12px" font-family="Consolas,Monaco,Andale Mono,monospace" fill="#4D4E53" text-anchor="middle" alignment-baseline="middle">Element</text></a><polyline points="341,25 351,20 351,30 341,25" stroke="#D4DDE4" fill="none"/><line x1="351" y1="25" x2="381" y2="25" stroke="#D4DDE4"/><a xlink:href="https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement" target="_top"><rect x="381" y="1" width="110" height="50" fill="#fff" stroke="#D4DDE4" stroke-width="2px" /><text x="436" y="30" font-size="12px" font-family="Consolas,Monaco,Andale Mono,monospace" fill="#4D4E53" text-anchor="middle" alignment-baseline="middle">HTMLElement</text></a><polyline points="491,25 501,20 501,30 491,25" stroke="#D4DDE4" fill="none"/><line x1="501" y1="25" x2="509" y2="25" stroke="#D4DDE4"/><line x1="509" y1="25" x2="509" y2="90" stroke="#D4DDE4"/><line x1="509" y1="90" x2="492" y2="90" stroke="#D4DDE4"/><a xlink:href="https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement" target="_top"><rect x="331" y="65" width="160" height="50" fill="#F4F7F8" stroke="#D4DDE4" stroke-width="2px" /><text x="411" y="94" font-size="12px" font-family="Consolas,Monaco,Andale Mono,monospace" fill="#4D4E53" text-anchor="middle" alignment-baseline="middle">HTMLMediaElement</text></a></svg></div>
a:hover text { fill: #0095DD; pointer-events: all;}
Properties
This interface also inherits properties from its ancestors HTMLElement
, Element
, Node
, and EventTarget
.
HTMLMediaElement.audioTracks
- A
AudioTrackList
that lists theAudioTrack
objects contained in the element. HTMLMediaElement.autoplay
- A
Boolean
that reflects theautoplay
HTML attribute, indicating whether playback should automatically begin as soon as enough media is available to do so without interruption.Note: Sites which automatically play audio (or videos with an audio track) can be an unpleasant experience for users, so it should be avoided when possible. If you must offer autoplay functionality, you should make it opt-in (requiring a user to specifically enable it). However, this can be useful when creating media elements whose source will be set at a later time, under user control. HTMLMediaElement.buffered
Read only- Returns a
TimeRanges
object that indicates the ranges of the media source that the browser has buffered (if any) at the moment thebuffered
property is accessed. HTMLMediaElement.controller
- Is a
MediaController
object that represents the media controller assigned to the element, ornull
if none is assigned. HTMLMediaElement.controls
- Is a
Boolean
that reflects thecontrols
HTML attribute, indicating whether user interface items for controlling the resource should be displayed. HTMLMediaElement.controlsList
Read only- Returns a
DOMTokenList
that helps the user agent select what controls to show on the media element whenever the user agent shows its own set of controls. TheDOMTokenList
takes one or more of three possible values:nodownload
,nofullscreen
, andnoremoteplayback
. HTMLMediaElement.crossOrigin
- Is a
DOMString
indicating the CORS setting for this media element. HTMLMediaElement.currentSrc
Read only- Returns a
DOMString
with the absolute URL of the chosen media resource. HTMLMediaElement.currentTime
- Is a
double
indicating the current playback time in seconds. Setting this value seeks the media to the new time. HTMLMediaElement.defaultMuted
- Is a
Boolean
that reflects themuted
HTML attribute, which indicates whether the media element's audio output should be muted by default. HTMLMediaElement.defaultPlaybackRate
- Is a
double
indicating the default playback rate for the media. HTMLMediaElement.disableRemotePlayback
- Is a
Boolean
that sets or returns the remote playback state, indicating whether the media element is allowed to have a remote playback UI. HTMLMediaElement.duration
Read only- Returns a
double
indicating the length of the media in seconds, or 0 if no media data is available. HTMLMediaElement.ended
Read only- Returns a
Boolean
that indicates whether the media element has finished playing. HTMLMediaElement.error
Read only- Returns a
MediaError
object for the most recent error, ornull
if there has not been an error. HTMLMediaElement.loop
- Is a
Boolean
that reflects theloop
HTML attribute, which indicates whether the media element should start over when it reaches the end. HTMLMediaElement.mediaGroup
- Is a
DOMString
that reflects themediagroup
HTML attribute, which indicates the name of the group of elements it belongs to. A group of media elements shares a commonMediaController
. HTMLMediaElement.mediaKeys
Read only- Returns a
MediaKeys
object ornull
. MediaKeys is a set of keys that an associated HTMLMediaElement can use for decryption of media data during playback. HTMLMediaElement.mozAudioCaptured
Read only- Returns a
Boolean
. Related to audio stream capture. HTMLMediaElement.mozFragmentEnd
- Is a
double
that provides access to the fragment end time if the media element has a fragment URI forcurrentSrc
, otherwise it is equal to the media duration. HTMLMediaElement.mozFrameBufferLength
-
Is a
unsigned long
that indicates the number of samples that will be returned in the framebuffer of eachMozAudioAvailable
event. This number is a total for all channels, and by default is set to be the number of channels * 1024 (e.g., 2 channels * 1024 samples = 2048 total).The
mozFrameBufferLength
property can be set to a new value for lower latency, larger amounts of data, etc. The size given must be a number between 512 and 16384. Using any other size results in an exception being thrown. The best time to set a new length is after the loadedmetadata event fires, when the audio info is known, but before the audio has started orMozAudioAvailable
events have begun firing. HTMLMediaElement.mozSampleRate
Read only- Returns a
double
representing the number of samples per second that will be played. For example, 44100 samples per second is the sample rate used by CD audio. HTMLMediaElement.muted
- Is a
Boolean
that determines whether audio is muted.true
if the audio is muted andfalse
otherwise. HTMLMediaElement.networkState
Read only- Returns a
unsigned short
(enumeration) indicating the current state of fetching the media over the network. HTMLMediaElement.paused
Read only- Returns a
Boolean
that indicates whether the media element is paused. HTMLMediaElement.playbackRate
- Is a
double
that indicates the rate at which the media is being played back. HTMLMediaElement.played
Read only- Returns a
TimeRanges
object that contains the ranges of the media source that the browser has played, if any. HTMLMediaElement.preload
- Is a
DOMString
that reflects thepreload
HTML attribute, indicating what data should be preloaded, if any. Possible values are:none
,metadata
,auto
. HTMLMediaElement.preservesPitch
- Is a
Boolean
that determines if the pitch of the sound will be preserved. If set tofalse
, the pitch will adjust to the speed of the audio. This is implemented with prefixes in Firefox (mozPreservesPitch
) and WebKit (webkitPreservesPitch
). HTMLMediaElement.readyState
Read only- Returns a
unsigned short
(enumeration) indicating the readiness state of the media. HTMLMediaElement.seekable
Read only- Returns a
TimeRanges
object that contains the time ranges that the user is able to seek to, if any. HTMLMediaElement.seeking
Read only- Returns a
Boolean
that indicates whether the media is in the process of seeking to a new position. HTMLMediaElement.sinkId
Read only- Returns a
DOMString
that is the unique ID of the audio device delivering output, or an empty string if it is using the user agent default. This ID should be one of theMediaDeviceInfo.deviceid
values returned fromMediaDevices.enumerateDevices()
,id-multimedia
, orid-communications
. HTMLMediaElement.src
- Is a
DOMString
that reflects thesrc
HTML attribute, which contains the URL of a media resource to use. HTMLMediaElement.srcObject
- Is a
MediaStream
representing the media to play or that has played in the currentHTMLMediaElement
, ornull
if not assigned. HTMLMediaElement.textTracks
Read only- Returns the list of
TextTrack
objects contained in the element. HTMLMediaElement.videoTracks
Read only- Returns the list of
VideoTrack
objects contained in the element.Gecko supports only single track playback, and the parsing of tracks' metadata is only available for media with the Ogg container format.
HTMLMediaElement.volume
- Is a
double
indicating the audio volume, from 0.0 (silent) to 1.0 (loudest).
Event handlers
HTMLMediaElement.onencrypted
- Sets the
EventHandler
called when the media is encrypted. HTMLMediaElement.onwaitingforkey
- Sets the
EventHandler
called when playback is blocked while waiting for an encryption key.
Obsolete attributes
These attributes are obsolete and should not be used, even if a browser still supports them.
HTMLMediaElement.initialTime
Read only- Returns a
double
that indicates the initial playback position in seconds. HTMLMediaElement.mozChannels
Read only- Returns a
double
representing the number of channels in the audio resource (e.g.,2
for stereo).
Obsolete event handlers
HTMLMediaElement.onmozinterruptbegin
- Sets the
EventHandler
called when the media element is interrupted because of the Audio Channel manager. This was Firefox-specific, having been implemented for Firefox OS, and was removed in Firefox 55. HTMLMediaElement.onmozinterruptend
- Sets the
EventHandler
called when the interruption is concluded. This was Firefox-specific, having been implemented for Firefox OS, and was removed in Firefox 55.
Methods
This interface also inherits methods from its ancestors HTMLElement
, Element
, Node
, and EventTarget
.
HTMLMediaElement.addTextTrack()
- Adds a text track (such as a track for subtitles) to a media element.
HTMLMediaElement.captureStream()
- Returns
MediaStream
, captures a stream of the media content. HTMLMediaElement.canPlayType()
- Determines whether the specified media type can be played back.
HTMLMediaElement.fastSeek()
- Directly seeks to the given time.
HTMLMediaElement.load()
- Resets the media to the beginning and selects the best available source from the sources provided using the
src
attribute or the<source>
element. HTMLMediaElement.mozCaptureStream()
- [enter description]
HTMLMediaElement.mozCaptureStreamUntilEnded()
- [enter description]
HTMLMediaElement.mozGetMetadata()
- Returns
Object
, which contains properties that represent metadata from the playing media resource as{key: value}
pairs. A separate copy of the data is returned each time the method is called. This method must be called after the loadedmetadata event fires. HTMLMediaElement.pause()
- Pauses the media playback.
HTMLMediaElement.play()
- Begins playback of the media.
HTMLMediaElement.seekToNextFrame()
- Seeks to the next frame in the media. This non-standard, experimental method makes it possible to manually drive reading and rendering of media at a custom speed, or to move through the media frame-by-frame to perform filtering or other operations.
HTMLMediaElement.setMediaKeys()
- Returns
Promise
. Sets theMediaKeys
keys to use when decrypting media during playback. HTMLMediaElement.setSinkId()
- Sets the ID of the audio device to use for output and returns a
Promise
. This only works when the application is authorized to use the specified device.
Obsolete methods
These methods are obsolete and should not be used, even if a browser still supports them.
HTMLMediaElement.mozLoadFrom()
- This method, available only in Mozilla's implementation, loads data from another media element. This works similarly to
load()
except that instead of running the normal resource selection algorithm, the source is simply set to theother
element'scurrentSrc
. This is optimized so this element gets access to all of theother
element's cached and buffered data; in fact, the two elements share downloaded data, so data downloaded by either element is available to both.
Specifications
Specification | Status | Comment |
---|---|---|
HTML Living Standard The definition of 'HTMLMediaElement' in that specification. |
Living Standard | No change from HTML5 |
HTML5 The definition of 'HTMLMediaElement' in that specification. |
Recommendation | Initial definition. |
Encrypted Media Extensions The definition of 'Encrypted Media Extensions' in that specification. |
Recommendation | Adds MediaKeys , MediaEncryptedEvent , setMediaKeys , onencrypted , and onwaitingforkey . |
Media Capture and Streams The definition of 'HTMLMediaElement' in that specification. |
Candidate Recommendation | Adds sinkId and setSinkId() , and captureStream() . |
Browser compatibility
Desktop | Mobile | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Basic support | Chrome
Full support
42
| Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support Yes | WebView Android
Full support
42
| Chrome Android
Full support
42
| Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
addTextTrack | Chrome
Full support
42
| Edge ? | Firefox ? | IE ? | Opera Full support Yes | Safari ? | WebView Android
Full support
42
| Chrome Android
Full support
42
| Edge Mobile ? | Firefox Android ? | Opera Android Full support Yes | Safari iOS ? | Samsung Internet Android ? |
audioTracks | Chrome No support No | Edge Full support Yes | Firefox
Full support
33
| IE ? | Opera Full support Yes | Safari ? | WebView Android No support No | Chrome Android No support No | Edge Mobile Full support Yes | Firefox Android
Full support
33
| Opera Android Full support Yes | Safari iOS ? | Samsung Internet Android ? |
autoplay | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support 30 | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support 30 | Safari iOS Full support Yes | Samsung Internet Android ? |
buffered | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 4 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
canPlayType | Chrome Full support Yes | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
captureStream | Chrome Full support 62 | Edge No support No | Firefox
Full support
15
| IE No support No | Opera Full support 49 | Safari No support No | WebView Android Full support 62 | Chrome Android Full support 62 | Edge Mobile No support No | Firefox Android
Full support
15
| Opera Android Full support 49 | Safari iOS No support No | Samsung Internet Android ? |
controller | Chrome No support No | Edge No support No | Firefox
No support
No
| IE ? | Opera No support No | Safari ? | WebView Android No support No | Chrome Android No support No | Edge Mobile No support No | Firefox Android
No support
No
| Opera Android No support No | Safari iOS ? | Samsung Internet Android ? |
controls | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
controlsList | Chrome Full support 58 | Edge ? | Firefox ? | IE ? | Opera Full support 45 | Safari ? | WebView Android Full support 58 | Chrome Android Full support 58 | Edge Mobile ? | Firefox Android ? | Opera Android Full support 42 | Safari iOS ? | Samsung Internet Android ? |
crossOrigin | Chrome Full support 43 | Edge Full support Yes | Firefox
Full support
22
| IE Full support 9 | Opera Full support Yes | Safari Full support 10 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
currentSrc | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
currentTime | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
defaultMuted | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 11 | IE ? | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support 14 | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
defaultPlaybackRate | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 20 | IE Full support 9 | Opera ? | Safari ? | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support 20 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
disableRemotePlayback | Chrome Full support 49 | Edge Full support Yes | Firefox Full support 20 | IE Full support 9 | Opera Full support Yes | Safari Full support Yes | WebView Android Full support 49 | Chrome Android Full support 49 | Edge Mobile Full support Yes | Firefox Android Full support 15 | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
duration | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
ended | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
error | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 43 | Chrome Android Full support 43 | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
fastSeek | Chrome ? | Edge No support No | Firefox Full support 31 | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile No support No | Firefox Android Full support 31 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
initialTime | Chrome ? | Edge No support No | Firefox No support 9 — 23 | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile No support No | Firefox Android No support 9 — 23 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
load | Chrome Full support 1 | Edge Full support 12 | Firefox Full support 3.6 | IE ? | Opera Full support Yes | Safari Full support 6 | WebView Android Full support 1 | Chrome Android Full support 18 | Edge Mobile Full support 12 | Firefox Android Full support 4 | Opera Android ? | Safari iOS Full support Yes | Samsung Internet Android ? |
loop | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 11 | IE Full support 9 | Opera ? | Safari ? | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
mediaGroup | Chrome ? | Edge No support No | Firefox
No support
No
| IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile No support No | Firefox Android
No support
No
| Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
mediaKeys | Chrome ? | Edge ? | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
mozAudioCaptured | Chrome ? | Edge ? | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
mozCaptureStreamUntilEnded | Chrome ? | Edge ? | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
mozChannels | Chrome No support No | Edge No support No | Firefox Full support 4 | IE No support No | Opera No support No | Safari No support No | WebView Android No support No | Chrome Android No support No | Edge Mobile No support No | Firefox Android Full support 4 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android ? |
mozFragmentEnd | Chrome ? | Edge ? | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
mozFrameBufferLength | Chrome No support No | Edge No support No | Firefox Full support 4 | IE No support No | Opera No support No | Safari No support No | WebView Android No support No | Chrome Android No support No | Edge Mobile No support No | Firefox Android Full support 4 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android ? |
mozGetMetadata | Chrome No support No | Edge No support No | Firefox Full support 17 | IE No support No | Opera No support No | Safari No support No | WebView Android No support No | Chrome Android No support No | Edge Mobile No support No | Firefox Android Full support 17 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android ? |
mozLoadFrom | Chrome No support No | Edge No support No | Firefox No support 3.6 — 24 | IE No support No | Opera No support No | Safari No support No | WebView Android No support No | Chrome Android No support No | Edge Mobile No support No | Firefox Android No support 4 — 24 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android ? |
mozSampleRate | Chrome No support No | Edge No support No | Firefox Full support 4 | IE No support No | Opera No support No | Safari No support No | WebView Android No support No | Chrome Android No support No | Edge Mobile No support No | Firefox Android Full support 4 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android ? |
muted | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
networkState | Chrome Full support 43 | Edge Full support Yes | Firefox
Full support
3.5
| IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
onerror | Chrome Full support Yes | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support Yes | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
onencrypted | Chrome ? | Edge ? | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
onmozinterruptbegin | Chrome ? | Edge ? | Firefox No support ? — 55 | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android No support ? — 55 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
onmozinterruptend | Chrome ? | Edge ? | Firefox No support ? — 55 | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android No support ? — 55 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
onwaitingforkey | Chrome Full support 55 | Edge No support No | Firefox ? | IE ? | Opera Full support 42 | Safari ? | WebView Android Full support 55 | Chrome Android Full support 55 | Edge Mobile No support No | Firefox Android ? | Opera Android Full support 42 | Safari iOS ? | Samsung Internet Android ? |
pause | Chrome Full support Yes | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
paused | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
play | Chrome Full support Yes | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
playbackRate | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 20 | IE Full support 9 | Opera ? | Safari ? | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support 20 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
played | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 15 | IE Full support 9 | Opera ? | Safari ? | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support 15 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
preload | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 4 | IE Full support 9 | Opera ? | Safari ? | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support 4 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
preservesPitch | Chrome
Full support
Yes
| Edge No support No | Firefox
Full support
20
| IE No support No | Opera No support No | Safari No support No | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android No support No | Safari iOS No support No | Samsung Internet Android ? |
readyState | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
seekToNextFrame | Chrome ? | Edge No support No | Firefox
Full support
49
| IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile No support No | Firefox Android
Full support
49
| Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
seekable | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 8 | IE Full support 9 | Opera ? | Safari ? | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support 8 | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
seeking | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
setMediaKeys | Chrome ? | Edge ? | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile ? | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
setSinkId | Chrome Full support 49 | Edge Full support 17 | Firefox
Full support
64
| IE No support No | Opera Full support 36 | Safari ? | WebView Android Full support 49 | Chrome Android Full support 49 | Edge Mobile No support No | Firefox Android
Full support
64
| Opera Android Full support 36 | Safari iOS ? | Samsung Internet Android ? |
sinkId | Chrome Full support 49 | Edge Full support 17 | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android Full support 49 | Chrome Android Full support 49 | Edge Mobile No support No | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
src | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
srcObject | Chrome
Partial support
52
| Edge
Partial support
Partial
| Firefox
Partial support
Partial
| IE ? | Opera
Partial support
39
| Safari ? | WebView Android
Partial support
52
| Chrome Android
Partial support
52
| Edge Mobile
Partial support
Partial
| Firefox Android
Partial support
Partial
| Opera Android
Partial support
39
| Safari iOS ? | Samsung Internet Android ? |
textTracks | Chrome ? | Edge Full support Yes | Firefox ? | IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile No support No | Firefox Android ? | Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
videoTracks | Chrome ? | Edge Full support Yes | Firefox
Full support
33
| IE ? | Opera ? | Safari ? | WebView Android ? | Chrome Android ? | Edge Mobile Full support Yes | Firefox Android
Full support
33
| Opera Android ? | Safari iOS ? | Samsung Internet Android ? |
volume | Chrome Full support 43 | Edge Full support Yes | Firefox Full support 3.5 | IE Full support 9 | Opera Full support Yes | Safari Full support 6 | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support Yes | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android ? |
Legend
- Full support
- Full support
- Partial support
- Partial support
- No support
- No support
- Compatibility unknown
- Compatibility unknown
- Experimental. Expect behavior to change in the future.
- Experimental. Expect behavior to change in the future.
- Non-standard. Expect poor cross-browser support.
- Non-standard. Expect poor cross-browser support.
- Deprecated. Not for use in new websites.
- Deprecated. Not for use in new websites.
- See implementation notes.
- See implementation notes.
- User must explicitly enable this feature.
- User must explicitly enable this feature.
- Uses a non-standard name.
- Uses a non-standard name.
- Requires a vendor prefix or different name for use.
- Requires a vendor prefix or different name for use.
See also
- References
<video>
and<audio>
HTML elements.HTMLVideoElement
andHTMLAudioElement
interfaces, derived fromHTMLMediaElement
.
- Articles