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 / 79568691
Accepted
user435421
user435421
Asked: 2025-04-11 19:08:56 +0800 CST2025-04-11 19:08:56 +0800 CST 2025-04-11 19:08:56 +0800 CST

O TailwindCSS v4 não gera certos estilos ao usar prefixo

  • 772

Estou usando um prefixo para diferenciar meu estilo de classes de terceiros. Quando não estou usando o prefixo, isso funciona bem:

fixed h-[5px] bg-green top-0 left-0 z-1000

Ao usar o prefixo, os estilos superior e esquerdo não são gerados no arquivo CSS do Tailwind, enquanto os outros funcionam bem.

tw:fixed tw:h-[5px] tw:bg-green tw:top-0 tw:left-0 tw:z-1000

Atualização: Estou usando @tailwinde tailwind.configporque esta é a única maneira de me livrar de todos os estilos desnecessários do Tailwind. Há um elemento de terceiros usando a classe outline(e alguns nomes de classe mais básicos do Tailwind) e o Tailwind pensa que é o seu estilo, então o Tailwind gera outlineo estilo em seu arquivo CSS, o que bagunça a interface.

Tentei usar @import "tailwindcss" prefix(tw);e outras combinações, mas dessa forma todos os estilos inúteis ficam presentes no css gerado, o que bagunça tudo.

index.csscontente:

@config "../../tailwind.config.js";

@tailwind base;
@tailwind components;
@tailwind utilities;

/* ... */

tailwind.config.js

/** @type {import('tailwindcss').Config} */
export default {
  mode: "jit",
  prefix: "tw",
  content: ["./src/**/*.{js,jsx,ts,tsx,css}"],
  theme: {
    colors: {
      'green': '#4287f5'
    }
  }
}
tailwind-css
  • 1 1 respostas
  • 41 Views

1 respostas

  • Voted
  1. Best Answer
    rozsazoltan
    2025-04-12T01:10:08+08:002025-04-12T01:10:08+08:00

    Importar

    A partir do TailwindCSS v4, a @tailwinddiretiva foi removida. Portanto, nenhuma dessas declarações é mais necessária. Em vez disso, você só precisa de uma única importação no topo do seu arquivo CSS:

    • @tailwindDiretivas removidas - StackOverflow
    @import "tailwindcss";
    
    @config "../../tailwind.config.js";
    

    Prefixo

    Se você quiser usar um prefixo, precisará incluir a importação novamente no topo do arquivo, assim:

    • Como adicionar tw-prefixo às classes Tailwind CSS em um projeto React Vite com Tailwind CSS v4? - StackOverflow
    @import "tailwindcss" prefix(tw);
    
    @config "../../tailwind.config.js";
    

    Entre minhas outras observações, gostaria de destacar que a mode: "jit"configuração no arquivo de configuração foi descontinuada desde o TailwindCSS v3, já que o modo JIT tem sido o padrão desde então.

    A partir da v4, se você estiver usando a configuração JavaScript legada, não precisará mais definir prefix: "tw"no arquivo de configuração; como mencionado, isso agora deve ser especificado durante a importação.

    Além disso, a partir do TailwindCSS v4, você não precisa definir a opção content; a v4 descobre automaticamente seus arquivos de origem (excluindo caminhos listados em .gitignore).

    • Detecção automática de fonte do TailwindCSS v4 - StackOverflow
    • Detecção de fonte e modo JIT - Este é um tipo diferente de resposta, a segunda parte pode ser interessante para você.

    Observação : certifique-se de que os arquivos listados em .gitignorenão sejam considerados pelo TailwindCSS ao compilar o CSS. É possível substituir a diretiva gitignore usando a @sourcediretiva (por exemplo, se você quiser excluir node_modules, mas precisar de alguns nomes de classe de um ou dois pacotes). Veja mais detalhes aqui: O TailwindCSS v4 não aplica estilos em pacotes/componentes .

    Então, se você ainda quiser usar o tailwind.config.js, isso é tudo que você precisa manter da configuração atual:

    /** @type {import('tailwindcss').Config} */
    export default {
      theme: {
        colors: {
          'green': '#4287f5'
        }
      }
    }
    

    Se você não quiser substituir todas as cores originais do TailwindCSS (por exemplo, bg-red-500, etc.) e quiser apenas estendê-las com as suas próprias, use a extendpropriedade assim:

    • Estendendo a escala de espaçamento padrão - TailwindCSS v3 Docs para configuração baseada em JS legado
    /** @type {import('tailwindcss').Config} */
    export default {
      theme: {
        extend: {
          colors: {
            'green': '#4287f5'
          }
        }
      }
    }
    

    Configuração CSS-first (recomendada a partir da v4)

    A partir da v4, você não precisa mais de tailwind.config.js. Portanto, você pode deixá-lo de lado e usar a nova configuração CSS-first. Com base no seu arquivo de configuração atual, ficaria assim:

    • Nova opção de configuração CSS-first na v4 - StackOverflow
    • Como usar temas de cores personalizados no TailwindCSS v4 - StackOverflow
    @import "tailwindcss" prefix(tw);
    
    @theme {
      --color-green: #4287f5; /* extend default colors with new green, what can use as e.g. tw:bg-green */
    }
    

    Nota : Neste caso, não há tailwind.config.jsmais necessidade do!

    Claro, se você não precisa de um prefixo, então use-o assim:

    @import "tailwindcss";
    
    @theme {
      --color-green: #4287f5; /* extend default colors with new green, what can use as e.g. bg-green */
    }
    

    Mais mudanças significativas da v4

    Desde a versão 4, várias mudanças significativas foram introduzidas; vale a pena revisar todas elas.

    • Quais são as principais mudanças do TailwindCSS v4? - StackOverflow
    • 0

relate perguntas

  • Como obter 2 divs próximos um do outro na visualização responsiva no vento favorável usando grade

  • Como publicar todas as classes personalizadas do tema no CSS do Tailwind?

  • TailwindCSS: a borda do botão de opção parece estranha

  • Como acessar todos os filhos de uma div no tailwindcss com evento hover?

  • como colocar uma divisória vertical que não fica completa no vento de cauda

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