O texto em um contêiner flexível não quebra no IE11


176

Considere o seguinte trecho:

.parent {
  display: flex;
  flex-direction: column;
  width: 400px;
  border: 1px solid red;
  align-items: center;
}
.child {
  border: 1px solid blue;
}
<div class="parent">
  <div class="child">
    Lorem Ipsum is simply dummy text of the printing and typesetting industry
  </div>
  <div class="child">
    Lorem Ipsum is simply dummy text of the printing and typesetting industry
  </div>
</div>

No Chrome, o texto está agrupado conforme o esperado:

insira a descrição da imagem aqui

Mas, no IE11, o texto não está quebrando :

insira a descrição da imagem aqui

Este é um bug conhecido no IE? (se sim, um ponteiro será apreciado)

Existe uma solução alternativa conhecida?


Essa pergunta semelhante não tem uma resposta definida e um ponteiro oficial.



1
O problema desaparece quando eu removo align-items: centerdo elemento pai. Isso parece ser o que está causando isso
Nathan Perrier

Respostas:


280

Adicione isto ao seu código:

.child { width: 100%; }

Sabemos que um filho em nível de bloco deve ocupar toda a largura do pai.

O Chrome entende isso.

O IE11, por qualquer motivo, deseja uma solicitação explícita.

Usando flex-basis: 100%ou flex: 1também funciona.

Nota: Às vezes, será necessário classificar os vários níveis da estrutura HTML para identificar qual contêiner obtém o width: 100%. Texto de quebra de CSS não funciona no IE


13
Eu tive que adicionar largura: 100%; para o pai. Esse bug parece ter várias correções, dependendo do contexto. Suspiro IE!
Dennis Johnsen

8
Em vez disso, use "max-width: 100%" no .child.
Tyler

2
Estou criando uma tabela usando flex (cada linha é um flex, com seus filhos tendo:. flex: 1 1 50%; display: flex; align-items: center;Não surpreendentemente, o IE falha ao digitar textos longos nas células. A configuração width:100%funciona, mas a configuração min-width: 100%não! Deveria, mas não ' t (como todas as coisas IE), então eu tentei max-width: 99%, e surpreendentemente, ele faz trabalho eu acho que usando. width:100%poderia ser melhor?
kumarharsh

1
Eu tive que remover flex-direction: columno pai para que isso funcionasse.
Dman

1
Esse problema parece exclusivo para flexionar colunas. Não acontece com linhas flexíveis.
Drazen Bjelovuk 2/11

40

Eu tive o mesmo problema e o ponto é que o elemento não estava adaptando sua largura ao contêiner.

Em vez de usar width:100%, seja consistente (não misture o modelo flutuante e o modelo flex) e use flex adicionando isto:

.child { align-self: stretch; }

Ou:

.parent { align-items: stretch; }

Isso funcionou para mim.


2
Sim, essa resposta também faz sentido (e provavelmente é mais correta que a largura). Em um dos meus projetos, definir largura: 100% não é possível e esta solução funciona bem.
precisa saber é o seguinte

11

Como Tyler sugeriu em um dos comentários aqui, usando

max-width: 100%;

na criança pode trabalhar (trabalhou para mim). Usar align-self: stretchapenas funciona se você não estiver usando align-items: center(o que eu fiz). width: 100%só funciona se você não tiver vários filhos dentro do seu flexbox que deseja mostrar lado a lado.


A largura máxima funcionou para mim quando aplicada ao mesmo contêiner em que alinhar itens: o flex-start foi colocado.
quer

7

Olá, eu tive que aplicar a largura de 100% ao seu elemento de avô. Não é seu (s) elemento (s) filho (s).

.grandparent {
    float:left;
    clear: both;
    width:100%; //fix for IE11 text overflow
}

.parent {
    display: flex;
    border: 1px solid red;
    align-items: center;
}

.child {
    border: 1px solid blue;
}

Eu tinha "width: auto;" no avô. Mudar para 100% corrigiu isso para mim.
precisa saber é o seguinte

2

De alguma forma, todas essas soluções não funcionaram para mim. Existe claramente um bug no IE flex-direction:column.

Eu só consegui funcionar depois de remover flex-direction:

flex-wrap: wrap;
align-items: center;
align-content: center;

0

As soluções propostas não me ajudaram com ".child {width: 100%;}", pois eu tinha uma marcação mais complicada. No entanto, encontrei uma solução - remova "align-items: center;", e isso também funciona para este caso.

.parent {
  display: flex;
  flex-direction: column;
  width: 400px;
  border: 1px solid red;
  /*align-items: center;*/
}
.child {
  border: 1px solid blue;
}
<div class="parent">
  <div class="child">
    Lorem Ipsum is simply dummy text of the printing and typesetting industry
  </div>
  <div class="child">
    Lorem Ipsum is simply dummy text of the printing and typesetting industry
  </div>
</div>


Você não precisa remover align-items: center. Veja stackoverflow.com/a/39365207/630170
kumarharsh

0

A única maneira de conseguir 100% consistentemente evitar esse erro da coluna de direção flexível é usar uma consulta de mídia de largura mínima para atribuir uma largura máxima ao elemento filho em telas de tamanho de área de trabalho.

.parent {
    display: flex;
    flex-direction: column;
}

//a media query targeting desktop sort of sized screens
@media screen and (min-width: 980px) {
    .child {
        display: block;
        max-width: 500px;//maximimum width of the element on a desktop sized screen
    }
}

Você precisará definir elementos filho naturalmente embutidos (por exemplo, <span>ou <a>) para algo diferente de embutido (principalmente exibição: bloco ou exibição: bloco embutido) para que a correção funcione.


0

Não encontrei minha solução aqui, talvez alguém seja útil:

.child-with-overflowed-text{
  word-wrap: break-all;
}

Boa sorte!


0
.grandparent{
   display: table;
}

.parent{
  display: table-cell
  vertical-align: middle
}

Isso funcionou para mim.


0

Eu também encontrei esse problema.

A única alternativa é definir uma largura (ou largura máxima) nos elementos filho. O IE 11 é um pouco estúpido, e eu apenas passei 20 minutos para perceber essa solução.

.parent {
  display: flex;
  flex-direction: column;
  width: 800px;
  border: 1px solid red;
  align-items: center;
}
.child {
  border: 1px solid blue;
  max-width: 800px;
  @media (max-width:960px){ // <--- Here we go. The text won't wrap ? we will make it break !
    max-width: 600px;
  }
  @media (max-width:600px){
    max-width: 400px;
  }
  @media (max-width:400px){
    max-width: 150px;
  }
}

<div class="parent">
  <div class="child">
    Lorem Ipsum is simply dummy text of the printing and typesetting industry
  </div>
  <div class="child">
    Lorem Ipsum is simply dummy text of the printing and typesetting industry
  </div>
</div>

-1

Eu tive um problema semelhante com imagens transbordando em um invólucro flexível.

Adicionar um flex-basis: 100%;ou mais flex: 1;ao filho transbordado corrigido funcionou para mim.


Essa solução já foi fornecida, anos atrás, e precisamos apenas de uma, portanto, evite postar respostas duplicadas.
Ason

-4

Por que usar uma solução complicada se uma simples também funciona?

.child {
  white-space: normal;
}
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.