Esta es una tecnología experimental
Comprueba la Tabla de compabilidad de navegadores cuidadosamente antes de usarla en producción.
La propiedad CSS de backdrop-filter le permite aplicar efectos gráficos como el desenfoque o el cambio de color al área detrás de un elemento. Debido a que se aplica a todo lo que está detrás del elemento, para ver el efecto debe hacer que el elemento o su fondo sean al menos parcialmente transparentes.
/* Valor de palabra clave */ backdrop-filter: none; /* URL al filtro SVG */ backdrop-filter: url(commonfilters.svg#filter); /* valores <filter-function> */ backdrop-filter: blur(2px); backdrop-filter: brightness(60%); backdrop-filter: contrast(40%); backdrop-filter: drop-shadow(4px 4px 10px blue); backdrop-filter: grayscale(30%); backdrop-filter: hue-rotate(120deg); backdrop-filter: invert(70%); backdrop-filter: opacity(20%); backdrop-filter: sepia(90%); backdrop-filter: saturate(80%); /* Múltiples filtros */ backdrop-filter: url(filters.svg#filter) blur(4px) saturate(150%); /* Valores globales */ backdrop-filter: inherit; backdrop-filter: initial; backdrop-filter: unset;
| Valor inicial | none |
|---|---|
| Applies to | all elements; In SVG, it applies to container elements excluding the defs element and all graphics elements |
| Heredable | no |
| Media | visual |
| Valor calculado | como se especifica |
| Animation type | a filter function list |
| Canonical order | el orden único no-ambigüo definido por la gramática formal |
Sintaxis
Valores
none- No se aplica filtro al fondo.
<filter-function-list>- Una lista separada por espacios de
<filter-function>o un filtro SVG que se aplicará al fondo.
Sintaxis formal
none | <filter-function-list>where
<filter-function-list> = [ <filter-function> | <url> ]+where
<filter-function> = <blur()> | <brightness()> | <contrast()> | <drop-shadow()> | <grayscale()> | <hue-rotate()> | <invert()> | <opacity()> | <saturate()> | <sepia()>where
<blur()> = blur( <length> )
<brightness()> = brightness( <number-percentage> )
<contrast()> = contrast( [ <number-percentage> ] )
<drop-shadow()> = drop-shadow( <length>{2,3} <color>? )
<grayscale()> = grayscale( <number-percentage> )
<hue-rotate()> = hue-rotate( <angle> )
<invert()> = invert( <number-percentage> )
<opacity()> = opacity( [ <number-percentage> ] )
<saturate()> = saturate( <number-percentage> )
<sepia()> = sepia( <number-percentage> )where
<number-percentage> = <number> | <percentage>
<color> = <rgb()> | <rgba()> | <hsl()> | <hsla()> | <hex-color> | <named-color> | currentcolor | <deprecated-system-color>where
<rgb()> = rgb( <percentage>{3} [ / <alpha-value> ]? ) | rgb( <number>{3} [ / <alpha-value> ]? ) | rgb( <percentage>#{3} , <alpha-value>? ) | rgb( <number>#{3} , <alpha-value>? )
<rgba()> = rgba( <percentage>{3} [ / <alpha-value> ]? ) | rgba( <number>{3} [ / <alpha-value> ]? ) | rgba( <percentage>#{3} , <alpha-value>? ) | rgba( <number>#{3} , <alpha-value>? )
<hsl()> = hsl( <hue> <percentage> <percentage> [ / <alpha-value> ]? ) | hsl( <hue>, <percentage>, <percentage>, <alpha-value>? )
<hsla()> = hsla( <hue> <percentage> <percentage> [ / <alpha-value> ]? ) | hsla( <hue>, <percentage>, <percentage>, <alpha-value>? )where
<alpha-value> = <number> | <percentage>
<hue> = <number> | <angle>
Ejemplo
CSS
.box {
background-color: rgba(255, 255, 255, 0.3);
border-radius: 5px;
font-family: sans-serif;
text-align: center;
line-height: 1;
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
max-width: 50%;
max-height: 50%;
padding: 20px 40px;
}
html,
body {
height: 100%;
width: 100%;
}
body {
background-image: url('https://interactive-examples.mdn.mozilla.net/media/examples/firefox-logo.svg');
background-position: center center;
background-repeat: no-repeat;
background-size: cover;
}
.container {
align-items: center;
display: flex;
justify-content: center;
height: 100%;
width: 100%;
}
HTML
<div class="container">
<div class="box">
<p>backdrop-filter: blur(10px)</p>
</div>
</div>
Resultado
Especificaciones
| Especificación | Estado | Comentario |
|---|---|---|
| Filter Effects Module Level 2 La definición de 'backdrop-filter' en esta especificación. |
Editor's Draft | Definición inicial. |
Compatibilidad con navegadores
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
backdrop-filter | Chrome
Soporte completo
76
| Edge Soporte completo 17 | Firefox
Soporte completo
70
| IE Sin soporte No | Opera
Soporte completo
34
| Safari
Soporte completo
9
| WebView Android Soporte completo 76 | Chrome Android
Soporte completo
76
| Firefox Android
Sin soporte
No
| Opera Android
Soporte completo
54
| Safari iOS
Soporte completo
9
| Samsung Internet Android Sin soporte No |
Leyenda
- Soporte completo
- Soporte completo
- Sin soporte
- Sin soporte
- Ver notas de implementación.
- Ver notas de implementación.
- El usuario debe de habilitar explícitamente esta característica.
- El usuario debe de habilitar explícitamente esta característica.
- Requiere de un prefijo de proveedor o un de nombre diferente para su uso.
- Requiere de un prefijo de proveedor o un de nombre diferente para su uso.