hifens
Baseline
2023
*
Newly available
Since â¨September 2023â©, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
* Some parts of this feature may have varying levels of support.
A propriedade CSS hyphens especifica como palavras devem ser hifenizadas quando o há quebra de texto em múltiplas linhas. Você pode prevenir a hifenização completamente, especificar pontos manualmente, ou permitir que o navegador insira automaticamente quando apropriado.
hyphens: none;
hyphens: manual;
hyphens: auto;
/* Valores globais */
hyphens: inherit;
hyphens: initial;
hyphens: unset;
Regras de hifenização são especÃficas para cada idioma. Em HTML, o idioma é determinado pelo atributo lang, e os navegadores irão utilizar hÃfen apenas caso este atributo esteja presente e se houver um dicionário de hifenização disponÃvel. Em XML, deve ser usado o atributo xml:lang.
Nota: As regras que definem como a hifenização é realizada não são explicitamente definidas pela especificação, então a hifenização exata pode variar de navegador para navegador.
| Initial value | manual |
|---|---|
| Aplica-se a | all elements |
| Inherited | yes |
| Computed value | as specified |
| Animation type | discrete |
Sintaxe
A propriedade hyphens é especificada como uma única palavra-chave escolhida da lista abaixo.
Valores
none-
Palavras não são separadas em quebras de linha, mesmo se seus caracteres sugiram pontos de quebra de linha. Linhas são quebradas apenas em espaços em branco.
manual-
Palavras são separadas apenas onde caracteres dentro de uma palavras sugiram oportunidades de quebra de linha. Veja abaixo Oportunidades sugeridas de quebra de linha para mais detalhes.
auto-
O navegador é livre para quebrar palavras automaticamente nos pontos apropriados de hifenização, seguindo quaisquer regras que ele escolher. Entretanto, oportunidades sugeridas de quebras de linha (veja Oportunidades sugeridas de quebra de linha abaixo) irão sobrepor a seleção automática de pontos de quebra quando presentes.
Nota:
O comportamento da configuração auto requer que a propriedade idioma seja indicada corretamente para que as regras de hifenização sejam selecionadas. Você deve especificar o idioma utilizando o atributo HTML lang para garantir que a hifenização automática seja aplicada na linguagem de sua escolha.
Oportunidades sugeridas de quebra de linha
Existem dois caracteres Unicode que podem ser utilizados para especificar manualmente potenciais pontos de quebra de linha no texto:
- U+2010 (HYPHEN)
-
O caractere hÃfen "duro" indica uma oportunidade de quebra de linha visÃvel. Mesmo que não haja quebra de linha naquele ponto, o hÃfen ainda será renderizado.
- U+00AD (SHY)
-
Um hÃfen invisivel, "suave". Este caractere não é renderizado visivelmente; ao invés, ele marca um local onde o browser deve quebrar a palavra se um hÃfen for necessário. Em HTML você pode usar
­para inserir um hÃfen suave.
Sintaxe formal
hyphens =
none |
manual |
auto
Exemplo
Este exemplo usa três classes, uma para cada configuração possÃvel da propriedade hyphens.
<ul>
<li>
<code>none</code>: sem hÃfen; transbordar se necessário
<p lang="en" class="none">An extreme­ly long English word</p>
</li>
<li>
<code>manual</code>: hÃfen apenas em &hyphen; ou &shy; (se
necessário)
<p lang="en" class="manual">An extreme­ly long English word</p>
</li>
<li>
<code>auto</code>: hÃfen onde o algorÃtmo decidir (se necessário)
<p lang="en" class="auto">An extreme­ly long English word</p>
</li>
</ul>
p {
width: 55px;
border: 1px solid black;
}
p.none {
-webkit-hyphens: none;
-ms-hyphens: none;
hyphens: none;
}
p.manual {
-webkit-hyphens: manual;
-ms-hyphens: manual;
hyphens: manual;
}
p.auto {
-webkit-hyphens: auto;
-ms-hyphens: auto;
hyphens: auto;
}
Especificações
| Specification |
|---|
| CSS Text Module Level 3 > # hyphens-property > |