AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79556563
Accepted
meursault
meursault
Asked: 2025-04-05 12:40:09 +0800 CST2025-04-05 12:40:09 +0800 CST 2025-04-05 12:40:09 +0800 CST

O uso seguro de palavras-chave com Django-summernote inibe a quebra de palavras, mesmo com quebra de palavras explícita

  • 772

Estou tentando usar o summernote com o django e estou encontrando esse problema: se eu colar 200 palavras de texto lorem ipsum embutido como teste no texfield, ele mostra o texto corretamente, mas em uma única linha que é muito grande e sai da tela para a direita.

Enquanto que se eu apenas colasse o lorem ipsum conforme codificado no modelo, a quebra de linha funcionaria perfeitamente.

Eu uso o tailwind aqui:

<div class="prose max-w-full break-words">
    {{ post.content | safe }}
</div>

O campo de conteúdo é um campo de texto:

content = models.TextField()

Tentei adicionar a palavra-chave linebreaks e definir a quebra de linha para quebrar a palavra, mas não adiantou nada:

<div class="prose max-w-full break-words" style="word-wrap: break-word;">
    {{ post.content | safe }}
</div>
css
  • 2 2 respostas
  • 40 Views

2 respostas

  • Voted
  1. Best Answer
    rozsazoltan
    2025-04-05T16:00:13+08:002025-04-05T16:00:13+08:00

    Encapsulamento adequado de palavras longas

    CSS -overflow-wrap: break-word;

    word-wrape overflow-wrapsignificam a mesma coisa.

    Nota : A propriedade era originalmente uma extensão da Microsoft não padrão e sem prefixo chamada word-wrap, e foi implementada pela maioria dos navegadores com o mesmo nome. Desde então, foi renomeada para overflow-wrap, word-wrapsendo um alias.

    • CSS:overflow-wrap - Documentação MDN

    div {
      width: 150px;
      border: 2px solid #000;
    }
    
    .example {
      overflow-wrap: break-word;
    }
    <div class="example">
      Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
    </div>
    <div>
      Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
    </div>

    TailwindCSS v3 -break-words

    No TailwindCSS v3, o break-wordsutilitário inclui a overflow-wrap: break-word;configuração.

    • Tipografia: Quebra de palavras - TailwindCSS v3

    Portanto, não há diferença entre escrever a solução diretamente no atributo de estilo CSS e usar obreak-words utilitário.

    <script src="https://cdn.tailwindcss.com"></script>
    
    <div class="flex gap-2">
      <div class="break-words w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
      <div class="w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
    </div>

    TailwindCSS v4 -wrap-break-word

    Exceto se você estiver usando a v4. Até a v3, algumas overflow-wrappropriedades eram agrupadas ilogicamente com word-break, mas na v4 elas eram separadas; então o equivalente de break-wordsde versões anteriores agora éwrap-break-word .

    • Tipografia: overflow-wrap - TailwindCSS v4 Docs
    • Tipografia: word-break - TailwindCSS v4 Docs

    <script src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"></script>
    
    <div class="flex gap-2">
      <div class="wrap-break-word w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
      <div class="w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
    </div>



    Quebra de texto adequada

    E quanto a textos longos? Por padrão, o CSS lida com quebra de texto, mas se você tiver substituído essa configuração anteriormente, o problema que você descreveu pode ocorrer. Felizmente, temos a opção de defini-lo corretamente novamente.

    CSS -white-space: normal;

    Por padrão, essa configuração garante que textos longos sejam quebrados em várias linhas. No entanto, se você a substituiu no seu código, ela pode não estar mais em vigor.

    • CSS:white-space - Documentação MDN

    div {
      width: 150px;
      border: 2px solid #000;
      white-space: preserve nowrap; /* you overrode it earlier */
    }
    
    .example {
      overflow-wrap: break-word;
      white-space: normal; /* but you can specifically revert it */
    }
    <div class="example">
      Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
    </div>
    <div>
      Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
    </div>

    TailwindCSS v3, v4 -whitespace-normal

    • Tipografia: espaço em branco - TailwindCSS v4 Docs

    @layer base {
      div {
        white-space: preserve nowrap; /* you overrode it earlier */
      }
    }
    <script src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"></script>
    
    <div class="flex gap-2">
      <div class="whitespace-normal wrap-break-word w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
      <div class="w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
    </div>

    Nota : A partir da v4, é importante usar camadas. Se você colocar seu estilo padrão personalizado fora de uma camada, ele terá maior especificidade do que qualquer estilo TailwindCSS colocado dentro de uma camada, o que significa que o TailwindCSS não poderá substituir configurações sem camadas.

    • CSS: Especificidade - MDN Docs
    • CSS: Qual camada será mais forte? - MDN Docs
    • A partir da v4, o estilo de redefinição não pode ser substituído pelas classes TailwindCSS - StackOverflow

    /* unlayered styling is too strong */
    /* the whitespace-normal class will be too weak, so it won't take effect */
    div {
      white-space: preserve nowrap; /* you overrode it earlier */
    }
    <script src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"></script>
    
    <div class="flex flex-col gap-2">
      <div class="whitespace-normal wrap-break-word w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
      <div class="w-32 border-2">
        Most words are short & don't need to break. But <strong>Antidisestablishmentarianism</strong> is long. The width is set to min-content, with a max-width of 11em.
      </div>
    </div>

    • 0
  2. rozsazoltan
    2025-04-05T16:32:44+08:002025-04-05T16:32:44+08:00

    Eu separei o estilo CSS base do @tailwindcss/typographyplugin. Você pode ler sobre quebra de linha e palavra aqui:

    • Como quebrar palavras e/ou textos - StackOverflow

    Plug-in:@tailwindcss/typography

    A proseclasse é um utilitário adicional deste plugin. Ela fornece estilo mais especializado para os filhos de elementos com a proseclasse.

    O plugin oficial Tailwind CSS Typography fornece um conjunto de proseclasses que você pode usar para adicionar belos padrões tipográficos a qualquer HTML simples que você não controla, como HTML renderizado do Markdown ou extraído de um CMS.

    • Playground TailwindCSS v3 com@tailwindcss/typography - TailwindCSS v3
    • Playground TailwindCSS v4 com@tailwindcss/typography - TailwindCSS v4

    Para que funcione corretamente, você precisa passar HTML válido. No Django, é assim que deve ser feito:

    safe

    <div class="prose">
      {{ post.content | safe }}
    </div>
    

    autoescape

    <div class="prose">
      {% autoescape off %}
        {{ post.content }}
      {% endautoescape %}
    </div>
    
    • Renderizando uma variável de modelo como HTML - StackOverflow

    Nota : No entanto, se o conteúdo for formatado, ou se você tiver estilos personalizados que substituam os estilos de prosa do TailwindCSS, podem surgir problemas. É uma boa ideia testá-lo em um ambiente separado e sem estilo. Se funcionar lá, o problema provavelmente está em seus próprios estilos, onde uma de suas regras é mais forte do que a Tipografia do TailwindCSS.

    • 0

relate perguntas

  • Prettier/VS Code adicionando um espaço antes de !important no CSS, causando quebra no WordPress

  • Como enviar parâmetros dinâmicos do arquivo react tsx para css

  • Grade CSS: agrupar e ajustar ao conteúdo

  • É possível alinhar gradientes entre elementos?

  • Bordas arredondadas com Box Shadow - Tailwind CSS

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve