SwiftHTML & CSSSolidityDesenvolvimento de JogosSolana/Rust
18.11.2024

Truncamento Automático de Texto em HTML Usando jQuery

Visão Geral Rápida

Se o texto não se encaixa em um container e se estende além de suas bordas, pode ser truncado e seguido por uma reticência. Isso pode ser alcançado usando propriedades CSS: overflow: hidden, white-space: nowrap e text-overflow: ellipsis. Além disso, é importante definir a largura do container de acordo com seu design.

.ellipsis {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis; /* Aqui é onde a mágica acontece */
}

Envolva seu texto longo dentro de um elemento HTML com a classe criada:

<div class="ellipsis">Aqui está um texto longo</div>

Dessa forma, o texto será truncado e será acrescentado uma reticência caso sua largura exceda a do bloco pai.

Texto Dinâmico e Compatibilidade Entre Navegadores

Se você precisa trabalhar com materiais de volumes variados, como manchetes de blogs, automatizar o processo de truncamento de texto e adicionar uma reticência é o ideal. Um plugin jQuery, como dotdotdot, pode lidar muito bem com essa tarefa, e você não precisará calcular manualmente os tamanhos.

Para truncamento em várias linhas, use as propriedades display: -webkit-box, -webkit-line-clamp e -webkit-box-orient. Esta solução é ideal para navegadores baseados em Webkit.

.multi-line-ellipsis {
  display: -webkit-box;
  -webkit-line-clamp: 3; /* Número de linhas visíveis */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis; /* E a mágica está aqui também */
}

Para garantir uma compatibilidade estável entre navegadores, é recomendado verificar a compatibilidade e procurar alternativas potenciais em recursos como Can I use.

Técnicas Adicionais e Desafios Potenciais a Considerar

Busca Binária para Dimensionamento Ótimo

Para containers que mudam dinamicamente, uma busca binária pode ajudar a estabelecer um tamanho de texto apropriado que garanta o truncamento correto e a adaptação a designs individuais.

Tooltips para Exibição Completa do Conteúdo

Utilize efeitos de hover com o atributo title para exibir o texto completo ao passar o cursor. Isso ajuda a manter a interface do usuário limpa e direta.

Classes CSS para Facilitar a Personalização

Criar classes CSS separadas para as configurações de reticência facilitará a padronização do estilo e permitirá modificações simples.

.dynamic-headline {
  position: relative;
  font-size: 1.5rem;
  /* Estilos adicionais considerando várias nuances */
}

Importância do Desempenho

Priorize soluções de alto desempenho. Sempre que possível, utilize CSS em vez de JavaScript, e garanta que os scripts estejam otimizados e executem rapidamente, especialmente quando se trabalha com muitos elementos.

Visualização

Imagine um container para conteúdo HTML (🚪) e o conteúdo em si (👕👗🧥):

🚪 Container (tag HTML):
[👕👗🧥👚👖👔👗👘] … O conteúdo é extenso demais para fechar completamente!

A reticência age como um cabide inteligente (🪝) que expande ou contrai dependendo da quantidade de conteúdo:

🚪 Container (com um cabide inteligente):
[👕👗🧥👚👖 ...] Tudo cabe perfeitamente.

Assim, a reticência (...) aqui funciona como um cabide inteligente, ajudando a manter a organização e se encaixando perfeitamente dentro do nosso container.

Atualização! Métodos Avançados e Melhores Práticas

Posicionamento Absoluto para Medidas Precisar

Usar posicionamento absoluto com elementos ocultos permite medir a largura do texto de forma mais precisa sem interromper o fluxo do documento.

Redimensionamento Responsivo para Conteúdo Móvel

Criar um evento de atualização único tornará mais fácil formatar elementos truncados quando o tamanho do container mudar devido ao redimensionamento da janela ou à adição de novo conteúdo.

Uso Estético do Caractere de Reticência

Use \u0026hellip; (que resulta em …) em vez de três pontos (...) para uma apresentação mais profissional e esteticamente agradável.

Testando para Confiabilidade

Verifique seus métodos em vários navegadores para garantir uma funcionalidade estável e esteja preparado para possíveis diferenças na exibição e interação.

Recursos Úteis

  1. Guia Completo para o Elemento Table | CSS-Tricks — uma exame detalhado de tabelas HTML e seu estilo CSS.
  2. text-overflow - CSS | MDN — documentação completa sobre a propriedade text-overflow.
  3. html - css ellipsis on second line - Stack Overflow — um guia internacional para gerenciar reticências em várias linhas.
  4. Can I use...? Suporte para HTML5, CSS3, etc. — um recurso para verificar a compatibilidade de navegadores com a propriedade CSS text-overflow.
  5. text-overflow | Codrops — uma referência para text-overflow com exemplos e explicações detalhadas.
  6. text-overflow: ellipsis; não está funcionando? - Stack Overflow — soluções para problemas comuns com a propriedade text-overflow.

Video

Did you like this article? Rate it from 1 to 5:

Thank you for voting!