media-playback-rate-button
A button that cycles through playback speed rates
Anatomy
<media-playback-rate-button></media-playback-rate-button>Behavior
Cycles through playback rates on click. The default rate list is [0.2, 0.5, 0.7, 1, 1.2, 1.5, 1.7, 2]. After the last rate, it wraps back to the first. If the current rate isn’t in the list (e.g., set programmatically), the button jumps to the next rate greater than the current one.
Styling
Display the current rate using the data-rate attribute:
media-playback-rate-button::after {
content: attr(data-rate) "\00D7";
}Accessibility
Renders a <button> with an automatic aria-label of "Playback rate {rate}" (e.g., "Playback rate 1.5"). Override with the label prop. Keyboard activation: Enter / Space.
Examples
Basic Usage
<video-player class="html-playback-rate-button-basic">
<video
src="https://stream.mux.com/BV3YZtogl89mg9VcNBhhnHm02Y34zI1nlMuMQfAbl3dM/highest.mp4"
autoplay
muted
playsinline
loop
></video>
<media-playback-rate-button class="html-playback-rate-button-basic__button">
</media-playback-rate-button>
</video-player>
.html-playback-rate-button-basic {
position: relative;
}
.html-playback-rate-button-basic video {
width: 100%;
}
.html-playback-rate-button-basic__button {
padding-block: 8px;
position: absolute;
bottom: 10px;
left: 10px;
background: rgba(255, 255, 255, 0.7);
backdrop-filter: blur(10px);
color: black;
border: 1px solid rgba(255, 255, 255, 0.3);
border-radius: 9999px;
padding-inline: 20px;
cursor: pointer;
}
.html-playback-rate-button-basic__button::after {
content: attr(data-rate) "\00D7";
}
import '@videojs/html/video/player';
import '@videojs/html/ui/playback-rate-button';
API Reference
Props
| Prop | Type | Default | Details |
|---|---|---|---|
disabled | boolean | false | |
| |||
label | string | function | '' | |
| |||
State
State is reflected as data attributes for CSS styling.
| Property | Type | Details |
|---|---|---|
rate | number | |
label | string |
Data attributes
| Attribute | Type | Details |
|---|---|---|
data-rate | number | |
| ||