Skip to content

Lack of support for applying extra spacing between Chinese/Japanese and Western text #401

@xfq

Description

@xfq

This issue applies to Chinese and Japanese.

In Chinese and Japanese composition, it is usually recommended to apply extra spacing between Chinese/Japanese han/kana characters and certain other types of text to make the text read better. The gap is typically used between han/kana characters and Latin letters, numbers, or punctuation, and should be smaller than an ASCII space would be.

ASCII spaces are not only too wide, but they spoil the semantics and behaviour of the text.

More:

The GAP (original text)

Currently, browsers do not support this feature, so content authors have to work around the problem by adding spaces manually, but because this produces too wide spaces and inserts characters that are not appropriate into the text, many texts don't have any gap between these runs of text.

In the css-text specification, text-autospace is intended to create 1/8em extra spacing between runs of ideographs/kana and Western letters/numerals.

In order to remediate texts where ASCII spaces have been used, the CSS text-autospace property also has a replace value, which will (without changing the underlying code points) replace the spaces with an appropriately-sized gap during the rendering of the text.

By default space should be added (the default value is normal, which is equivalent to ideograph-alpha and ideograph-numeric.)

Gecko, Blink, and Webkit browsers all fail to add the extra spacing between runs of ideographs and non-ideographic letters.

Priority

Given that, though not ideal, people have been forced to omit the gap or (worse) use ASCII spaces, this is prioritised as an advanced issue, however this is really a basic feature of Chinese/Japanese text, and so needs to be addressed.

Tests & results

text-autospace: ideograph-alpha ideograph-numeric; creates a thin gap between runs of han characters and both ASCII letters and digits in Chinese

text-autospace: ideograph-alpha ideograph-numeric; creates a thin gap between runs of kanji and both romaji letters and digits in Japanese

text-autospace: ideograph-alpha ideograph-numeric; creates a thin gap between runs of hiragana and both romaji letters and digits in Japanese

text-autospace: ideograph-alpha ideograph-numeric; creates a thin gap between runs of katakana and both romaji letters and digits in Japanese

text-autospace: ... replace; replaces ASCII spaces with a thin gap when adding text spacing in Japanese

Action taken

Bug reports: Gecko 1Gecko 2Blink 1Blink 2WebKit 1WebKit 2WebKit 3

GH issues: spacing

Outcomes

As of version 18.4 WebKit browsers now support text-autospace: ideograph-alpha|ideograph-numeric, but they don't yet support the replace keyword. This is problematic because, many websites currently use a space to separate these items, even though it is not ideal.

WebKit also applies no-autospace as the default, contrary to the CSS spec, which expects the value to be normal. There is an ongoing discussion about whether the default behaviour should add or not add gaps.

Gecko is considering support but it is not yet available.

The Blink issue has been marked as fixed on Jul 10, 2025. It is not yet available on Blink browsers.

Unicode proposal: EAST ASIAN AUTO SPACING (Proposal)

text-autospaceBlinkGeckoWebKit
ideograph-alpha
ideograph-numeric
replace

Metadata

Metadata

Assignees

No one assigned

    Labels

    doc:clreqUsed for gap analysis (only) to indicate target document.gapThe first comment in this issue is read by the gap-analysis document.i:spacingText spacingl:zhChinesep:advanceds:haniChinese scriptx:blinkBlink needs to fix this.x:clreqThis affects the clreq group of languages.x:geckoGecko needs to fix this.x:jpanThis affects the jlreq group of languages.x:webkitWebKit needs to fix this.

    Type

    No type

    Projects

    Status

    Bug fix in progress

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions