Upcoming Changes


    Overview

    Tailwind follows semantic versioning, so we never introduce breaking changes until a new major release (v2.0 is the next one).

    Rather than drop a bunch of breaking changes on you at once though, we use feature flags as an incremental adoption strategy so you can opt-in to breaking changes early, and save the upgrade hassle down the road.

    The following breaking changes are currently available in Tailwind behind flags.

    Tailwind v1.7.0 introduced new and gap-y-{n} utilities to replace the existing col-gap-{n} and row-gap-{n} utilities. We currently include both by default, but the old utilities will be removed in v2.0.

    Tailwind v1.8.0 introduced new layers purge mode which will be the default in v2.0. It purges all layers (base, components, and utilities) by default, whereas the previous default mode (conservative, now deprecated) only purged the utilities layer.

    With the introduction of the new preserveHtmlElements purge option (which is true by default), we consider this more aggressive purging mode very safe, and it is unlikely to actually be a breaking change in your application.

    You should see an even smaller CSS file by default with the new layers mode enabled, and shouldn’t see any negative consequences unless you were deliberately relying on the fact that Tailwind was previously not purging the base or components layers by default.

    To opt-in to using the new layers mode by default, use the purgeLayersByDefault flag:

    1. // tailwind.config.js
    2. module.exports = {
    3. future: {
    4. purgeLayersByDefault: true,
    5. // ...
    6. }

    If you’d like to only purge the utilities layer (like the conservative mode did), you can still opt-in with this flag, but then explicitly specify that you’d only like to purge the utilities layer:

    Here’s a list of the included font-size utilities with their corresponding default line-heights:

    1. module.exports = {
    2. // ...
    3. theme: {
    4. fontSize: {
    5. xs: ['0.75rem', { lineHeight: '1rem' }],
    6. sm: ['0.875rem', { lineHeight: '1.25rem' }],
    7. base: ['1rem', { lineHeight: '1.5rem' }],
    8. lg: ['1.125rem', { lineHeight: '1.75rem' }],
    9. xl: ['1.25rem', { lineHeight: '1.75rem' }],
    10. '2xl': ['1.5rem', { lineHeight: '2rem' }],
    11. '4xl': ['2.25rem', { lineHeight: '2.5rem' }],
    12. '6xl': ['4rem', { lineHeight: '1' }],
    13. },
    14. },
    15. }

    This is a breaking change because you might be using a utility like text-2xl in your project right now without adding an explicit line-height like leading-8, which means you are implicitly relying on the current default of 1.5 and the new defaults will change how your project looks.

    The easiest way to update your project for 2.0 is to look through your project for any places where you are using a font-size utility without adding a line-height utility and explicitly add leading-normal, so that when you upgrade to 2.0 the new line-height defaults won’t impact your design.

    To opt-in to this change now and ease the transition to 2.0, use the defaultLineHeights flag:

    In Tailwind 2.0, the font-thin utility will be renamed to font-extralight and font-hairline will be renamed to font-thin to better match the naming in the .

    1. // tailwind.config.js
    2. module.exports = {
    3. future: {
    4. standardFontWeights: true,
    5. },
    6. }

    ← Release Notes