NEWCKEditor 5 Long-term Support is here! Find out more
Sign up (with export icon)

Font family, size, and color

Contribute to this guideShow the table of contents

The font feature lets you change font family, size, and color (including background color).

Demo

Copy link

Use the toolbar dropdowns in the demo below to control the font size Font size and font family Font family. You can also change both the font color Font color and the font background color Font background color with predefined palette or color picker Color picker.

The message you want to convey is the most important part of any document. But how you do it also plays a great role. Font faces, sizes, and colors may radically change the way the reader perceives your content.

Sans-serif fonts, like Arial or Verdana, are universally used in electronic publications intended to be read on-screen.

Serif font families are traditionally used in print media, making reading from paper easier. The basic print text is black on white, but modern printing techniques and electronic media have made room for more diverse colors in documents. 

Monospaced fonts, like Courier, are associated with computer terminals and are often used to represent code listings and machine printouts.

Font colors and background colors are used to draw attention to parts of the text. You should use them with caution, though, as similar colors may lead to unreadable results. A properly chosen set, however, will greatly improve text visibility and readability and may be used to aid accessibility.

You may use custom text and background colors to create infoboxes or quotations.

Text size also plays an important role in driving the reader's attention.

Large text is used for important information that really needs to stick out.

Small text can provide some optional details. You can also use it for information you don't want to expose too much.

Additional feature information

Copy link

The font styles, just like the basic text styles, can serve many purposes. You can apply the font size setting globally or to a selected part of the text to make it catch the eye of the reader. Using different font families can help differentiate between sections of the content that serve various purposes (like main text and a side quotation or a recap). Different font colors can work as markers and guides just like font background colors that stand out even more and draw attention.

The plugin enables the following features in the rich-text editor:

  • FontFamily – Change the font family by applying inline <span> elements with a font-family in the style attribute.
  • FontSize – Control the font size by applying inline <span> elements that either have a CSS class or a font-size in the style attribute.
  • FontColor – Control the font color by applying inline <span> elements with a color in the style attribute.
  • FontBackgroundColor – Control the font background color by applying inline <span> elements with a background-color in the style attribute.
Note

You can remove all font formatting with the remove format feature.

Installation

Copy link

After installing the editor, add the feature to your plugin list and toolbar configuration:

import { ClassicEditor, Font } from 'ckeditor5';

ClassicEditor
	.create( document.querySelector( '#editor' ), {
		licenseKey: '&lt;YOUR_LICENSE_KEY&gt;', // Or 'GPL'.
		plugins: [ Font, /* ... */ ],
		toolbar: [ 'fontSize', 'fontFamily', 'fontColor', 'fontBackgroundColor', /* ... */ ]
		fontFamily: {
			// Configuration.
		}
		fontColor: {
			// Configuration.
		}
		// ...
	} )
	.then( /* ... */ )
	.catch( /* ... */ );
Copy code

You can also add just one or a selected few of the font features to your plugin list and the toolbar configuration:

import { ClassicEditor, FontFamily } from 'ckeditor5';

ClassicEditor
	.create( document.querySelector( '#editor' ), {
		plugins: [ FontFamily, /* ... */ ],
		toolbar: [ 'fontFamily', /* ... */ ]
	} )
	.then( /* ... */ )
	.catch( /* ... */ );
Copy code

Configuring the font family feature

Copy link

You can configure which font family options are supported by the WYSIWYG editor. Use the config.fontFamily.options configuration option to do so.

Use the special 'default' keyword to use the default font family defined in the web page styles. It removes any custom font family.

For example, the following editor supports two font families besides the default one:

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontFamily: {
            options: [
                'default',
                'Ubuntu, Arial, sans-serif',
                'Ubuntu Mono, Courier New, Courier, monospace'
            ]
        },
        toolbar: [
            'heading', 'bulletedList', 'numberedList', 'fontFamily', 'undo', 'redo'
        ]
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

This text has the "Ubuntu, Arial, sans-serif" font family set.

This text has the "Ubuntu Mono, Courier New, Courier, monospace" font family set.

Accepting all font names

Copy link

By default, all font-family values that are not specified in the config.fontFamily.options are stripped. You can enable support for all font names by using the config.fontFamily.supportAllValues option.

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontFamily: {
            options: [
                // Font family configuration options are described in the "Configuring the font family feature" section.
                // ...
            ],
            supportAllValues: true
        },
        // More of editor's configuration.
        // ...
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

Configuring the font size feature

Copy link

It is possible to configure which font size options are supported by the WYSIWYG editor. Use the config.fontSize.options configuration option to do so.

Use the special 'default' keyword to use the default font size defined in the web page styles. It removes any custom font size.

The font size feature supports two ways of defining the configuration: using predefined (named) presets or simple numeric values.

Using the predefined presets

Copy link

The font size feature defines 4 named presets:

  • 'tiny'
  • 'small'
  • 'big'
  • 'huge'

Each size is represented in the view as a <span> element with the text-* class. For example, the 'tiny' preset looks as follows in the editor data:

<span class="text-tiny">...</span>
Copy code

The CSS definition for the classes (presets) must be included in the web page styles where the edited content is rendered.

Here is an example of the font size CSS classes:

.ck-content .text-tiny {
    font-size: 0.7em;
}

.ck-content .text-small {
    font-size: 0.85em;
}

.ck-content .text-big {
    font-size: 1.4em;
}

.ck-content .text-huge {
    font-size: 1.8em;
}
Copy code

An example of an editor that supports two font sizes:

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontSize: {
            options: [
                'tiny',
                'default',
                'big'
            ]
        },
        toolbar: [
            'heading', 'bulletedList', 'numberedList', 'fontSize', 'undo', 'redo'
        ]
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

This is a mixed text with different font sizes: small and big.

Using numerical values

Copy link

The font size feature also supports numerical values.

In this case, each size is represented in the view as a <span> element with the font-size style set in px. For example, 14 will be represented in the editor data as:

<span style="font-size: 14px">...</span>
Copy code

Here is an example of the WYSIWYG editor that supports numerical font sizes. Note that 'default' is controlled by the default styles of the web page:

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontSize: {
            options: [
                9,
                11,
                13,
                'default',
                17,
                19,
                21
            ]
        },
        toolbar: [
            'heading', 'bulletedList', 'numberedList', 'fontSize', 'undo', 'redo'
        ]
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

9px

11px

13px

Normal

17px

19px

21px

Accepting all font sizes

Copy link

By default, all font-size values that are not specified in the config.fontSize.options are stripped. You can enable support for all font sizes by using the config.fontSize.supportAllValues option.

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontSize: {
            options: [
                // Numerical values.
                // ...
            ],
            supportAllValues: true
        },
        // More of editor's configuration.
        // ...
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code
Note

This option can be used only in combination with numerical values.

Configuring the font color and font background color features

Copy link

Both font color and font background color features are configurable and share the same configuration format.

Note

Please note that font color and font background color are separate plugins. They must be enabled and configured individually.

Check out the WYSIWYG editor below with both features customized using the editor configuration:

The text in this sample has multiple font colors and font background colors.

Here are some examples of custom colors not defined in the configuration that might be recognized and used in the "document colors" section.

Specifying available colors

Copy link

It is possible to configure which colors are available in the color dropdown. Use the config.fontColor.colors and config.fontBackgroundColor.colors configuration options to do so.

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontColor: {
            colors: [
                {
                    color: 'hsl(0, 0%, 0%)',
                    label: 'Black'
                },
                {
                    color: 'hsl(0, 0%, 30%)',
                    label: 'Dim grey'
                },
                {
                    color: 'hsl(0, 0%, 60%)',
                    label: 'Grey'
                },
                {
                    color: 'hsl(0, 0%, 90%)',
                    label: 'Light grey'
                },
                {
                    color: 'hsl(0, 0%, 100%)',
                    label: 'White',
                    hasBorder: true
                },
                // More colors.
                // ...
            ]
        },
        fontBackgroundColor: {
            colors: [
                {
                    color: 'hsl(0, 75%, 60%)',
                    label: 'Red'
                },
                {
                    color: 'hsl(30, 75%, 60%)',
                    label: 'Orange'
                },
                {
                    color: 'hsl(60, 75%, 60%)',
                    label: 'Yellow'
                },
                {
                    color: 'hsl(90, 75%, 60%)',
                    label: 'Light green'
                },
                {
                    color: 'hsl(120, 75%, 60%)',
                    label: 'Green'
                },
                // More colors.
                // ...
            ]
        },
        toolbar: [
            'heading', 'bulletedList', 'numberedList', 'fontColor', 'fontBackgroundColor', 'undo', 'redo'
        ]
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

Changing the geometry of the color grid

Copy link

You can configure the number of columns in the color dropdown by setting the config.fontColor.columns and config.fontBackgroundColor.columns configuration options.

Usually, you will want to use this option when changing the number of available colors.

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontColor: {
            colors: [
                // 9 colors defined here.
                // ...
            ]

            columns: 3, // So, you can display them in 3 columns.

            // Optional configuration of the number of document colors.
            // ...
        },
        fontBackgroundColor: {
            columns: 6,
            // Background color options.
            // ...
        },
        toolbar: [
            'heading', 'bulletedList', 'numberedList', 'fontColor', 'fontBackgroundColor', 'undo', 'redo'
        ]
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

Documents colors

Copy link

The font and font background color dropdowns contain the “Document colors” section. It lists the colors already used in the document for the users to be able to easily reuse them (for consistency purposes).

By default, the number of displayed document colors is limited to one row, but you can adjust it (or remove the whole section) by using the config.fontColor.documentColors or config.fontBackgroundColor.documentColors options.

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontColor: {
            // Display 6 columns in the color grid.
            columns: 6,

            // And 12 document colors (2 rows of them).
            documentColors: 12,

            // Optional available font colors configuration.
            // ...
        },
        fontBackgroundColor: {
            // Remove the "Document colors" section.
            documentColors: 0,

            // Background color options.
            // ...
        },
        toolbar: [
            'heading', 'bulletedList', 'numberedList', 'fontColor', 'fontBackgroundColor', 'undo', 'redo'
        ]
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

Color picker

Copy link

You can set colors from outside of the pre-configured palette using the “Color picker” option available at the bottom of the color selection dropdown.

Color picker applies colors in the HSL format as it is the default for the font color feature. You can change this using the config.fontColor.colorPicker.format option. Available color formats are defined in the ColorPickerOutputFormat type. This change will not affect the color input – it always accepts only values given in the hex format (with or without the # sign at the beginning).

To turn off the color picker entirely for the given feature, set the config.fontColor.colorPicker (or config.fontBackgroundColor.colorPicker) option to false.

ClassicEditor
    .create( document.querySelector( '#editor' ), {
        // ... Other configuration options ...
        fontColor: {
            colorPicker: {
                // Use 'hex' format for output instead of 'hsl'.
                format: 'hex'
            }
        },
        fontBackgroundColor: {
            // Do not display the color picker.
            colorPicker: false
        },
        toolbar: [
            'heading', 'bulletedList', 'numberedList', 'fontColor', 'fontBackgroundColor', 'undo', 'redo'
        ]
    } )
    .then( /* ... */ )
    .catch( /* ... */ );
Copy code

Email client color format compatibility

Copy link

When designing content for emails, it is important to be aware that many email clients have limited support for various color formats. For maximum compatibility in email templates, consider the following limitations:

Unsupported color formats in most email clients:

Copy link
  • hsl
  • hsla
  • hwb
  • lab
  • lch
  • oklab
  • oklch
  • color-mix
  • rgba
Copy link
  • Hexadecimal (for example, #FF0000)
  • RGB (for example, rgb(255, 0, 0))
  • Named colors (for example, red)

Using these compatible formats will ensure your content displays consistently across different email clients.

Copy link

Here are some more CKEditor 5 features that can help you format your content:

  • Basic text styles – The essentials, like bold, italic, and others.
  • Styles – Apply pre-configured styles to existing elements in the editor content.
  • Text alignment – Because it does matter whether the content is left, right, centered, or justified.
  • Case change – Turn a text fragment or block into uppercase, lowercase, or title case.
  • Headings – Divide your content into sections.
  • Highlight – Mark important words and passages, aiding a review or drawing attention to specific parts of the content.
  • Format painter – Easily copy text formatting and apply it in a different place in the edited document.
  • Remove format – Easily clean basic text formatting.

Common API

Copy link

The FontFamily plugin registers the following components:

  • The 'fontFamily' dropdown.

  • The 'fontFamily' command.

    The number of options and their names correspond to the config.fontFamily.options configuration option.

    You can change the font family of the current selection by executing the command with a desired value:

    editor.execute( 'fontFamily', { value: 'Arial' } );
    
    Copy code

    The value must correspond to the first font name in the configuration string. For the following default configuration:

    fontFamily.options = [
        'default',
        'Arial, Helvetica, sans-serif',
        'Courier New, Courier, monospace',
        'Georgia, serif',
        'Lucida Sans Unicode, Lucida Grande, sans-serif',
        'Tahoma, Geneva, sans-serif',
        'Times New Roman, Times, serif',
        'Trebuchet MS, Helvetica, sans-serif',
        'Verdana, Geneva, sans-serif'
    ]
    
    Copy code

    the 'fontFamily' command will accept the corresponding strings as values:

    • 'Arial'
    • 'Courier New'
    • 'Georgia'
    • 'Lucida Sans Unicode'
    • 'Tahoma'
    • 'Times New Roman'
    • 'Trebuchet MS'
    • 'Verdana'

    Note that passing an empty value will remove the fontFamily attribute from the selection (default):

    editor.execute( 'fontFamily' );
    
    Copy code

The FontSize plugin registers the following components:

  • The 'fontSize' dropdown.

  • The 'fontSize' command.

    The number of options and their names correspond to the config.fontSize.options configuration option.

    You can change the font size of the current selection by executing the command with a desired value:

    // For numerical values:
    editor.execute( 'fontSize', { value: 10 } );
    
    // For named presets:
    editor.execute( 'fontSize', { value: 'small' } );
    
    Copy code

    Passing an empty value will remove any config.fontSize set:

    editor.execute( 'fontSize' );
    
    Copy code

The FontColor plugin registers the following components:

  • The 'fontColor' dropdown.

  • The 'fontColor' command.

    You can change the font color of the current selection by executing the command with a desired value:

    editor.execute( 'fontColor', { value: 'rgb(30, 188, 97)' } );
    
    Copy code

    Passing an empty value will remove the font color from the selection:

    editor.execute( 'fontColor' );
    
    Copy code

The FontBackgroundColor plugin registers the following components:

  • The 'fontBackgroundColor' dropdown.

  • The 'fontBackgroundColor' command.

    You can change the font background color of the current selection by executing the command with a desired value:

    editor.execute( 'fontBackgroundColor', { value: 'rgb(30, 188, 97)' } );
    
    Copy code

    Passing an empty value will remove the font background color from the selection:

    editor.execute( 'fontBackgroundColor' );
    
    Copy code
Note

We recommend using the official CKEditor 5 inspector for development and debugging. It will give you tons of useful information about the state of the editor such as internal data structures, selection, commands, and many more.

Content compatibility

Copy link

The Font plugin provides basic support for the deprecated <font> tag.

While <font color> is always supported, to use <font face> and <font size> you need to enable the config.fontFamily.supportAllValues and config.fontSize.supportAllValues options respectively.

Text formatted with <font> is accepted by the plugin, but the editor always returns the markup in a modern format, so the transformation is one way.

Contribute

Copy link

The source code of the feature is available on GitHub at https://github.com/ckeditor/ckeditor5/tree/master/packages/ckeditor5-font.