U+ UnicodeFYI
Безопасность

Разъединитель нулевой ширины (ZWNJ)

U+200C. Предотвращает объединение соседних символов. Необходим в персидском/арабском для правильных форм букв и используется в деванагари для предотвращения лигатур.

· Обновлено

What is ZWNJ (Zero Width Non-Joiner)?

ZWNJ stands for Zero Width Non-Joiner, encoded at U+200C. Like its counterpart ZWJ (Zero Width Joiner, U+200D), ZWNJ is an invisible formatting character with zero visual width. Where ZWJ instructs rendering engines to join or ligate adjacent characters, ZWNJ does the opposite: it prevents joining, ligature formation, or cursive connection between characters that would otherwise be combined by default.

ZWNJ is primarily used in scripts that employ cursive or ligature-forming typography — most notably Arabic, Persian (Farsi), Urdu, Devanagari, and other Brahmic scripts — as well as in general typography for ligature control in Latin script.

How ZWNJ Works in Arabic and Persian

In Arabic script, most letters connect to their neighbors in a cursive flow, changing their shape based on position. Persian (Farsi) is written in Arabic script with a few additional characters. In both languages, there are grammatical and typographic situations where a word boundary or morpheme boundary should visually break the cursive connection, even though the characters are part of the same word.

For example, the Persian word می‌رود (miravad, "goes") is written with a ZWNJ between می and رود to show that these are two morphemes — a prefix and a verb — without inserting a full space. The ZWNJ breaks the cursive connection and creates a slight visual gap (a "half-space") while keeping the word as a single typographic unit for justification and line-breaking purposes. This usage is standard and required for correct Persian typography.

How ZWNJ Works in Devanagari and Brahmic Scripts

In Devanagari (used for Hindi, Sanskrit, Marathi, Nepali), ZWNJ prevents the formation of conjunct consonants. When two consonants appear together, the Devanagari rendering system normally forms a conjunct ligature — a combined glyph. Inserting ZWNJ between them preserves both consonants in their independent (virama-terminated) forms rather than combining them.

For example: क + ् + ष normally renders as the conjunct क्ष (ksha). Inserting ZWNJ (क + ् + ZWNJ + ष) renders as क् ष — the halant form of ka followed by independent sha.

ZWNJ in Latin Typography

In Latin script, ZWNJ can prevent automatic ligature formation. High-quality typography systems (TeX, OpenType) automatically ligate character pairs like fi, fl, ff, ffi, ffl. In some contexts — such as compound words in German where the ligature would cross a morpheme boundary — the ligature is typographically incorrect. ZWNJ inserted between the two letters prevents the ligature.

ZWNJ and ZWJ Comparison

Property ZWNJ (U+200C) ZWJ (U+200D)
Full name Zero Width Non-Joiner Zero Width Joiner
Effect on joining Prevents joining/ligature Encourages joining/ligature
Primary use Persian half-space, Devanagari conjunct prevention Emoji sequences, Arabic joining
Visual width Zero Zero
Unicode category Cf (Format) Cf (Format)

Security and Data Considerations

ZWNJ, like all invisible characters, can be used to insert hidden content into text. Two visually identical strings may differ because one contains ZWNJ characters. This matters for:

  • Password comparison: A password with embedded ZWNJ is technically different from one without
  • Text search: Search engines typically ignore ZWNJ for matching purposes
  • Data normalization: Applications processing user input should define a policy for stripping or preserving ZWNJ

Quick Facts

Property Value
Code point U+200C
Name ZERO WIDTH NON-JOINER
Unicode category Cf (Format character)
Visual width Zero — completely invisible
Primary script use Persian (Farsi), Arabic, Devanagari, Brahmic scripts
Persian function Half-space for morpheme boundary (می‌رود)
Latin use Prevents automatic fi/fl ligatures
Introduced Unicode 1.1 (1993)

Связанные термины

Ещё в Безопасность

Bidi Text Attack

Exploiting Unicode bidirectional control characters to disguise malicious code or filenames. The …

Normalization Attack

Exploiting Unicode normalization to bypass security filters. Input validated before normalization may …

Атака с использованием омографов IDN

Использование визуально похожих Unicode-символов в доменных именах для имитации легитимных сайтов. аpple.com …

Атака через замену двунаправленного текста

Использование Unicode-символов переопределения двунаправленности (U+202A–U+202E, U+2066–U+2069) для маскировки вредоносных имён файлов или …

Обнаружение смешанных систем письма

Идентификация текста, смешивающего символы из разных письменностей (например, латиница + кириллица). Основная …

Омоглиф

Символы из разных письменностей, которые выглядят идентично или очень похоже, например, латинская …

Похожий символ

Официальный термин Unicode для пар символов, которые можно визуально перепутать, определённых в …

Соединитель нулевой ширины (ZWJ)

U+200D. Запрашивает объединение соседних символов. Критичен для emoji-последовательностей (👩+ZWJ+💻=👩‍💻). В индийских письменностях …

Спуфинг Unicode

Использование функций Unicode для обмана пользователей: омоглифы для поддельных доменов, переопределение bidi …