env()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since January 2020.
A função CSS env()
pode ser usada para inserir o valor de uma variável de ambiente definida pelo agente do usuário em seu CSS, de uma maneira semelhante à função var()
e propriedades personalizadas. A diferença é que, além de serem definidas pelo agente do usuário em vez de serem definidas pelo usuário, as variáveis de ambiente têm escopo global para um documento, enquanto as propriedades personalizadas têm um escopo para o(s) elemento(s) no(s) qual(is) é/são declarado(s).
body {
padding: env(safe-area-inset-top, 20px) env(safe-area-inset-right, 20px)
env(safe-area-inset-bottom, 20px) env(safe-area-inset-left, 20px);
}
Além disso, ao contrário das propriedades personalizadas, que não podem ser usadas fora do escopo das declarações, a função env()
pode ser usada em qualquer parte do valor de uma propriedade ou em qualquer parte de um descriptor (por exemplo, regras Media). À medida que a especificação evolui, essa também pode ser usada em outros lugares, como em seletores.
Originalmente fornecido pelo navegador iOS para permitir que os desenvolvedores coloquem seu conteúdo em uma safe area (área segura) na janela de visualização, os valores de safe-area-inset-*
definidos na especificação podem ser usados para ajudar a garantir que o conteúdo seja visível até mesmo para usuários que usam uma tela não retangular.
Sintaxe
/* Usando os quatro valores de inserção safe area sem valores de fallback */
env(safe-area-inset-top);
env(safe-area-inset-right);
env(safe-area-inset-bottom);
env(safe-area-inset-left);
/* Usando-os com valores de fallback */
env(safe-area-inset-top, 20px);
env(safe-area-inset-right, 1em);
env(safe-area-inset-bottom, 0.5vh);
env(safe-area-inset-left, 1.4rem);
Valores
safe-area-inset-top
,safe-area-inset-right
,safe-area-inset-bottom
,safe-area-inset-left
-
As variáveis
safe-area-inset-*
são quatro variáveis de ambiente que definem um retângulo por seus valores de inserção: top, right, bottom e left a partir da borda da janela de visualização, no qual é seguro colocar o conteúdo sem o risco de ser cortado pela forma de um visor não retangular. Para janelas de visualização retangulares, como o monitor de um laptop comum, seu valor é igual a zero. Para telas não retangulares - como um visor de um relógio redondo - os quatro valores definidos pelo agente do usuário formam um retângulo de modo que todo o conteúdo dentro do retângulo seja visível.
Nota: Ao contrário de outras propriedades CSS, os nomes de propriedades definidos pelo agente do usuário fazem distinção entre maiúsculas e minúsculas.
Sintaxe formal
<env()> =
env( <custom-ident> <integer [0,∞]>* , <declaration-value>? )
Exemplos
O exemplo abaixo faz uso do segundo parâmetro opcional de env()
, que permite fornecer um valor de fallback caso a variável de ambiente não esteja disponível.
<p>
Se a função <code>env()</code> é suportada em seu navegador, o texto deste
parágrafo deverá estar na borda <i>top</i>, <i>right</i> e <i>bottom</i>, ter
50px de preenchimento entre a borda e o texto. O CSS é equivalente ao
preenchimento: <code>padding: 0 0 0 50px</code>, porque, ao contrário de
outras propriedades CSS, os nomes de propriedades do agente do usuário
diferenciam letras maiúsculas de minúsculas.
</p>
p {
width: 300px;
border: 2px solid red;
padding: env(safe-area-inset-top, 50px) env(safe-area-inset-right, 50px)
env(safe-area-inset-bottom, 50px) env(SAFE-AREA-INSET-LEFT, 50px);
}
Exemplo com valores
padding: env(
safe-area-inset-bottom,
50px
); /* zero para todos agentes do usuário que são retangulares*/
padding: env(
Safe-area-inset-bottom,
50px
); /* 50px porque as propriedades do agente do usuário diferenciam maiúsculas de minúsculas */
padding: env(
x,
50px 20px
); /* como se estivesse preenchendo: '50px 20px' que foram definidos, porque x não é uma variável de ambiente válida */
padding: env(
x,
50px,
20px
); /* ignorado '50px, 20px' porque não é um valor de preenchimento válido e x não é uma variável de ambiente válida */
A sintaxe fallback, como de propriedades customizadas, permite vírgulas. Mas se o valor da propriedade não suportar vírgulas, o valor não é válido.
Nota: As propriedades do agente do usuário não são redefinidas pela propriedade all.
Especificações
Specification |
---|
CSS Environment Variables Module Level 1 # env-function |
Compatibilidade com navegadores
BCD tables only load in the browser