Quais são as melhores práticas para lidar com quebras de linha desejadas no design responsivo da web?

17

Projecto uma grande quantidade de itens simples de uma página para vendas ou email. Costumo encontrar problemas com títulos e minhas quebras de linha desejadas em diferentes larguras de mídia.

Por exemplo, eu poderia ter um título como:

Nosso novo thingamabob é a melhor coisa desde pão fatiado!

Com absolutamente nenhuma atenção às quebras de linha, a linha quebra assim:

Nosso novo thingamabob é a melhor coisa desde
pão fatiado!

No tamanho total da web, gostaria de quebrar a linha após "o". Criando duas linhas.

Nosso novo thingamabob é a
melhor coisa desde pão fatiado!

Para uma tela com largura média, eu quebraria duas vezes:

Nosso novo thingamabob
é a melhor coisa
desde pão fatiado!

Para telas ainda mais estreitas, eu iria depois de "new", depois de "thingamabob" e depois de "thing". Criando quatro linhas.

Nosso novo
thingamabob
é a melhor coisa
desde pão fatiado!

Eu realmente não quero usar tags de quebra ( <br>) porque isso define as quebras em todos os tamanhos. Até agora eu usei consultas de mídia e porcentagens de largura para os vários h1- h5etiquetas para que a largura das forças de tag de uma pausa. Mas isso parece "hacky" para mim ( às vezes também é muito temperamental, com base no texto atual).

Qual é a melhor maneira de controlar quebras de linha sem codificá-las no html?

Scott
fonte

Respostas:

12

Só o aconselho com base no fato de que é usado para pequenos trechos de texto e não para parágrafos.

A formatação das manchetes pode e deve ser controlada o máximo possível, dentro de limites razoáveis . JavaScript ou elementos extras desnecessários não são "limites razoáveis" .

Espaços sem quebra, por outro lado ... podem ser úteis quando usados ​​com moderação.
Colocá-los entre os pares de palavras e trigêmeos que você gostaria de manter juntos pode produzir os resultados desejados.

No entanto, você não pode usar muitos consecutivamente, dependendo do tamanho das palavras que estiver usando, vincular muitos forçará o texto a sair da janela de exibição ou de seu contêiner.

Algumas experiências rápidas em seu próprio conjunto de palavras devem revelar as melhores para vincular.

Para o exemplo nesta pergunta, o HTML pode se parecer com:

<span>Our&nbsp;New thingamabob is&nbsp;the best&nbsp;thing since&nbsp;sliced&nbsp;bread!</span>

Na verdade, não há CSS necessário aqui. O CSS neste exemplo que eu produzi é apenas por diversão.


Em poucas palavras, a chave para esse método é limitar o número de lugares em que o texto pode ser quebrado.


Depois de reler a pergunta, percebo que não satisfazi completamente os requisitos. Para esse caso específico, e assumindo que existem outras páginas que requerem a mesma atenção, eu definiria uma única <br>para um ponto de interrupção de largura total. Eu reutilizaria a mesma classe em cada uma das páginas no local mais ideal do cabeçalho.

Essa <br>classe entraria em colapso com algo menor que a largura total, agindo como se nem estivesse lá, com o uso de consultas de mídia. Em tamanhos de viewport menores que a largura total, contamos &nbsp;apenas com os.

Outro exemplo com um single<br> mais próximo da marca.

O HTML:

<span>
    Our&nbsp;New thingamabob is&nbsp;the<br class="full-width-breakpoint"/> best&nbsp;thing since&nbsp;sliced&nbsp;bread!
</span>

O CSS:

@media screen and (max-width:550px) {    /* Max Width depends on your design */     
    .full-width-breakpoint {             /* only experimentation or */
        display:none;                    /* calculation will reveal */
        line-height:0;                   /* the best max-width */
    }
}
Dom
fonte
4
Para algo tão específico quanto o exemplo da pergunta, este é o caminho a seguir #
Zach Saucier
1
Este parece ser o método mais fácil e direto. Obrigado.
Scott Scott
6

A melhor prática é reconhecer que você não tem controle real sobre quebras de linha na Web e é melhor projetar com isso em mente.

Qualquer solução em contrário, invariavelmente, terá que ser hacky. Como será um hack, o HTML não adere a quebras de linha definidas pelo usuário fora da codificação. Você poderia fazer isso com JS facilmente. Configure seus pontos de interrupção com vãos vazios com classes exclusivas e, com base no tamanho da janela de visualização, você poderá injetar tags BR em cada SPAN desejado.

Existem alguns estilos CSS que funcionarão em navegadores mais recentes para controlar a maneira como o navegador lida com quebra de linha, mas ainda não fornecerá o controle exato que você está procurando nessa situação.

Por outro lado, se seu objetivo não é tanto controlar quebras de linha específicas, mas para garantir que seu bloco de texto seja 'empilhado' em linhas relativamente uniformes, eu definiria a largura do DIV de maneira diferente para cada viewport. Não será perfeito, mas provavelmente bem próximo e pode ser o melhor compromisso.

DA01
fonte
Este. Além disso, se você ainda não o viu, leia A Dao of Web Design de John Allsopp aqui: alistapart.com/article/dao
bemdesign
3

Existe um plugin jquery para isso, Balance Text .

É um plugin criado pela Adobe,text-wrap: balance; criado juntamente com a proposta da Adobe de obter uma opção de CSS que faria isso como o recurso Balance Ragged Lines do Adobe InDesign (parece ótimo, mas mesmo que seja aceito, levará anos até que os navegadores o suportem).

O plugin, no entanto, funciona agora. Ele equilibra qualquer elemento que tenha a classe balance-textou use o jQuery como$('.some-elements').balanceText();

Limitações

Atualmente, esse código funciona apenas em texto em tags no nível do bloco sem elementos embutidos.

Na demonstração 4 você verá como tudo dentro do seu bloco de texto equilibrado como um <a>link, <span>S ou ênfase, como <em>, <strong>, <b>, <i>etc é removido.

Além disso, comparando demos 1, 2 e 5, você verá que você parece necessidade de usar tanto a classe CSS ea chamada jQuery.


Parece moderadamente confiável, mas às vezes com falhas - na hora de escrever, às vezes escapa quando está em uma coluna lateral, deixando órfãos solitários (mas parece funcionar 95% + do tempo e ainda não o vi escapar, exceto quando em uma coluna lateral), e por razões inexplicáveis, minhas demos não funcionam no Firefox, mas as demos da Adobe funcionam (perfeitas no IE9 +, não podem ser testadas no IE8 no momento). Se você usá-lo, considere algum tempo de teste.

user56reinstatemonica8
fonte
Não faço ideia, mas a página do GitHub inclui uma descrição de como funciona. Parece que ele usa apenas a pesquisa DOM e as coisas básicas de manipulação, então você pode se safar usando Sizzle (o seletor do jQuery) e remendando as coisas de manipulação de elementos, conforme necessário. Mas isso poderia facilmente espiral em um monte de trabalho ...
user56reinstatemonica8
Eu imagino que esse é o "algoritmo" descrito no início do arquivo leia-me. Basicamente, eles estão apenas dizendo que usaram o jQuery para facilitar a compatibilidade entre navegadores.
user56reinstatemonica8
@DumbNic Se você está preocupado com o tamanho do jQuery, tente usar o Zepto.js , mas não tenho 100% de certeza de que ele funciona com esse plug-in nativamente. Eu não acho que há uma versão de baunilha js disponíveis (embora seja possível fazer um)
Zach Saucier
Mistério downvote ... Eu acho que alguém realmente não gosta jQuery
user56reinstatemonica8
3

Eu tenho que lidar com isso de forma um tanto regular, com sugestões de designers que desejam que as coisas desapareçam de uma certa maneira. Eu descobri que a maneira mais direta de fazer isso é colocar um espaço com uma classe dentro do texto e, em seguida, ter esse espaço display: block;para as consultas de mídia.

Portanto, seria algo como isto:

<p>This is some text and I want <span class="mobile-only-line-break">only this text to break, but only on mobile</span></p>

Então eu teria CSS com algo parecido com isto:

@media all and (max-width: 767px) {
.mobile-only-line-break { 
display: block;
}
}

Você ainda precisa passar por isso para garantir que as coisas quebrem da maneira que você deseja para todas as larguras.

Se for um problema frequente, você poderá criar seu próprio conjunto de classes de quebra de linha no Twitter Bootstrap ou em qualquer sistema de grade que estiver usando, modelando os nomes das classes após qualquer convenção de nomenclatura que estiver usando.

Joel M.
fonte
2

Você pode usar o JavaScript para detectar a largura da tela e escrever a versão correta (com <br> 's como você a encontra em sua postagem) em uma div vazia via innerHTML.

Infelizmente, as "quebras da web desejadas" e as "melhores práticas da web" não caminham juntas. Deixe de lado seu desejo perfeccionista de colocar todas as palavras no lugar certo - há muitas possibilidades de tela e muitos leitores que não têm a mentalidade de designer que você precisa para se preocupar com quebras de linha em seus títulos. Consulte o Responsive Web Design para entender melhor esses problemas.

Steve
fonte
1
Isso é muito difícil de ser feito de forma responsiva e requer muito cálculo. Eu não recomendo usando esta abordagem
Zach Saucier
A questão parece ter mudado. Eu dei a resposta para a pergunta que ele fez na época, que era exibir as quebras de linha onde ele as queria.
26614 Steve Steve
Eu estava abordando as "quebras de linha desejadas". Dei a ele uma implementação teórica de JS para obter o que ele queria. Meu segundo parágrafo diz a minha posição, no entanto, e sou contra essa abordagem. O RWD é o caminho a seguir, e é isso que eu uso nos meus aplicativos.
26414 Steve Steve
2

Meu método atual ...

<h1>Our New thingamabob is the best thing since sliced bread!</h1>

E o CSS:

@media only screen 
and (min-device-width : 320px) 
and (max-device-width : 480px) {
   h1 { margin: 0 auto; text-align: center; width: 280px; }
}

@media only screen 
and (min-width : 321px) {
    h1 { margin: 0 auto; text-align: center; width: 280px; }
}


@media only screen 
and (max-width : 320px) {
    h1 { margin: 0 auto; text-align: center; width: 280px; }
}


@media only screen 
and (min-device-width : 768px) 
and (max-device-width : 1024px) {
    h1 { margin: 0 auto; text-align: center; width: 550px; }
}


@media only screen 
and (min-device-width : 768px) 
and (max-device-width : 1024px) 
and (orientation : landscape) {
    h1 { margin: 0 auto; text-align: center; width: 800px; }
}


@media only screen 
and (min-device-width : 768px) 
and (max-device-width : 1024px) 
and (orientation : portrait) {
    h1 { margin: 0 auto; text-align: center; width: 550px; }
}


@media only screen 
and (min-width : 1224px) {
    h1 { margin: 0 auto; text-align: center; width: 800px; }
}

/* Large screens ----------- */
@media only screen 
and (min-width : 1824px) {
    h1 { margin: 0 auto; text-align: center; width: 1200px; }
}


@media
only screen and (-webkit-min-device-pixel-ratio : 1.5),
only screen and (min-device-pixel-ratio : 1.5) {
    h1 { margin: 0 auto; text-align: center; width: 280px; }
}

Às vezes, as larguras precisam de algum ajuste com base no texto real sendo usado, mas esse é o esquema geral que eu uso. Essencialmente, reduzindo a largura da h1tag para que a linha quebre onde eu quero que ela quebre.

Isso funciona, apenas exige testes exaustivos para garantir que ocorram interrupções quando desejado. Porém, testes completos são necessários em qualquer caso. Portanto, não é necessariamente mais trabalho nesse sentido.

Scott
fonte
Nota: você pode aplicar margin: 0 auto; text-align: center;apenas uma vez fora de uma consulta de mídia e ele será aplicado a todos eles
Zach Saucier
1
Além disso, com algo tão específico para o conteúdo, seria melhor usar apenas extensões internas ... Todo esse CSS é um pouco demais e, assim que você altera o tamanho da fonte ou algo semelhante, tudo terá que ser alterado de acordo.
Zach Saucier
Acordado. Os tamanhos das fontes são controlados globalmente para todos os tamanhos de mídia. Esta foi apenas uma amostra da marcação.
Scott
1

Você pode adicionar white-space: nowrape colocar <wbr>nos locais em que deseja permitir quebras de linha. Se isso não for suficiente e você desejar um bom controle com consultas de mídia, ainda poderá adicionar classes como<wbr class="mobileOnly">

<wbr>doc: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/wbr

Tom Esterez
fonte