CSS Reference Property

column-fill

The column-fill property specifies how content is distributed and filled into columns in a multi-column layout.

Using this property, you can control whether columns should be balanced, or not.

If the columns are not set to be balanced, they are filled sequentially; some columns may end up partially filled, or with no content at all. If they are balanced, the browser (or any other use agent) will do its best so that their heights are as close to equal as possible. It should try to minimize variations in column height, while honoring forced breaks, widows and orphans, and other properties that may affect column heights.

The effect of column-fill is mostly obvious when the height of the multi-column element is specified. The following image shows the difference between a multi-column layout whose columns are not balanced, and one whose columns are balanced using column-fill.

column-fill-values
The difference between balanced and non-balanced columns in a multi-column layout.

Notice how the first two columns are filled and the third one is half-full in the first layout, while they are equal-height in the balanced layout.

Official Syntax

  • Syntax:

    column-fill: auto | balance
  • Initial: balance
  • Applies To: multi-column elements
  • Animatable: no

Notes

A third value balance-all also exists, which relates to paged media. See the Values section below for information.

Values

auto
Fill columns sequentially. Equal heights are not a goal or a requirements.
balance
Balance content equally between columns, as far as possible. In paged media, only the last page is balanced.
balance-all
Balance content equally between columns, as far as possible. In paged media, all pages are balanced.

Examples

.element {
    /* create multi-column layout in the element */
    column-width: 12em;
    /* increase the gap between columns. See column-gap for more information */
    column-gap: 2em;

    column-fill: balance;
    /* OR */
    column-fill: auto;
}
                

Live Demo

The following demo will show three equal-height columns (currently it’s only supported in Firefox):

View this demo on the Codrops Playground

The following screenshot shows how the result looks in a supporting browser:

column-fill

Browser Support

The column-fill is currently supported only in Firefox.

Written by

Last updated July 16, 2015 at 6:48 pm by Sara Soueidan

Do you have a suggestion, question or want to contribute? Submit an issue.