Zero Width Non-Joiner (ZWNJ)
U+200C. Bitişik karakterlerin birleşmesini önler. Farsça/Arapça'da doğru harf biçimleri için ve Devanagari'de bitişik harfleri önlemek için gereklidir.
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) |
İlgili Terimler
Güvenlik içinde daha fazlası
Exploiting Unicode bidirectional control characters to disguise malicious code or filenames. The …
Farklı alfabelerden özdeş veya çok benzer görünen karakterler, örneğin Latin 'a' ve …
Alan adlarında görsel olarak benzer Unicode karakterler kullanarak meşru siteleri taklit etme. …
Unicode'un görsel olarak karıştırılabilecek karakter çiftleri için resmi terimi, confusables.txt (UCD) dosyasında …
Farklı alfabelerden karakterleri karıştıran metni tanımlama (örn. Latin + Kiril). Homoglyph saldırılarına …
Exploiting Unicode normalization to bypass security filters. Input validated before normalization may …
Kullanıcıları aldatmak için Unicode özelliklerini kullanma: sahte alan adları için homoglyph'ler, sahte …
U+200D. Bitişik karakterlerin birleştirilmesini ister. Emoji dizileri için kritik (👩+ZWJ+💻=👩💻). Hint alfabelerinde …
Unicode çift yönlü geçersiz kılma karakterlerini (U+202A–U+202E, U+2066–U+2069) kullanarak kötü amaçlı dosya …