Javanese (draft)

Updated 16 April, 2022

This page brings together basic information about the Javanese script and its use for the Javanese language. It aims to provide a brief, descriptive summary of the modern, printed orthography and typographic features, and to advise how to write Javanese using Unicode.


Select part of this sample text to show a list of characters, with links to more details. Source
Change size:   28px


ꦧꦧ꧀꧇꧒꧇​꧋ꦱꦧꦼꦤ꧀ꦲꦸꦮꦺꦴꦁꦢꦂ​ꦧꦺꦲꦏ꧀ꦠꦸꦩꦿꦥ꧀ꦲ​ꦏ꧀ꦭꦤ꧀ꦏꦧꦼꦧꦱ꧀ꦱꦤ꧀ꦏꦧꦼꦧ​ꦱ꧀ꦱꦤ꧀ꦏꦁꦠꦶꦤꦸ​ꦭꦶꦱ꧀ꦲꦶꦁꦥꦿꦚꦠꦤ꧀ꦲꦸ​ꦩꦸꦩ꧀ꦲꦶ​ꦏꦶꦠꦤ꧀ꦥꦥꦶ​ꦭꦶꦃꦏꦱꦶꦃ꧈​ꦏꦧꦺꦃꦮꦫꦠꦭꦤ꧀ꦲ​ꦢꦶꦭ꧀ꦲꦶꦁꦱꦩꦸꦧꦫꦁ꧈​ꦏꦪꦠꦧꦺꦢꦧꦺꦢ​ꦤꦶꦁꦫꦱ꧀​ ꦮꦂꦤꦤꦶꦁꦲꦮꦏ꧀​ ꦧꦺꦢꦧꦺꦢ​ꦤꦶꦁꦭꦤꦁꦭꦤ꧀ꦮꦢꦺꦴꦤ꧀​ ꦧꦱ꧈​ꦄꦒꦩ꧈​ꦥꦸꦭꦶꦠꦶꦏ꧀ ꦭꦤ꧀ꦥꦤꦼꦩꦸ​ꦭꦶꦪꦤꦺ꧈​ꦲꦱꦭ꧀ꦲꦸꦱꦸꦭ꧀ꦱꦸ​ꦏꦸꦧꦁꦱꦭ​ꦤ꧀ꦧꦼꦧꦿꦪꦤ꧀​ ꦲꦏ꧀ꦢꦂꦧꦺ꧈​ꦠꦠꦭꦲꦶꦂꦭꦤ꧀ꦏ​ꦭꦸꦁꦒꦸꦃꦲꦤ꧀ꦭꦶꦪꦤꦺ꧉

Note: ZWSP has been added between orthographic syllables in the above text in order to allow the text to wrap. The major browsers don't wrap it automatically.

Usage & history

Use of the Javanese script ended abruptly during the Second World War, when its use was forbidden by the occupying forces. Its use has since declined, and everyday Javanese is now generally written in the Latin script, although the Javanese orthography is still taught in most elementary schools and some junior high schools in Javanese speaking areas. There are no newspapers or magazines being printed in the Javanese script.

ꦲꦏ꧀ꦱꦫꦗꦮ ꦲꦤꦕꦫꦏ

The Javanese script derives from the ancient Brahmi script, via Old Kawi. It is the pre-colonial script of the Javanese language spoken on the Indonesian islands of Java and Bali and is used to write the Tengger and Osing languages, also spoken in Java and Bali. Historically it was also used to write the Bali language, which is now written largely in the Latin and the (closely related) Balinese scripts, and the Sunda language, which is now written in the Latin and Arabic scripts.

Numerous efforts to standardize the script were made in the late 19th to early 20th-century, with the invention of the script's first metal type and the development of concise orthographic guidelines.

Sources: Scriptsource, Wikipedia.

Basic features

Javanese is an abugida, ie. consonants carry an inherent vowel sound that is overridden, where needed, using vowel signs. In Javanese, consonants carry an inherent vowel, which can be a or o. See the table to the right for a brief overview of features of the modern Javanese orthography.

Javanese text runs left to right in horizontal lines.

Words are not separated by spaces, however syllables may be separated by ZWSP, as long as they don't fall inside a stack. Spaces may be used to separate phrases.

The 20 consonant letters used for pure Javanese words are supplemented by 1o more which are used as honorifics, a little like capital letters, and 5 more used in Sanskrit words. Repertoire extensions for 8 non-native sounds are achieved by applying the cecak telu diacritic to characters.

Consonant clusters are represented by stacked consonants (many subjoined consonants have alternative shapes) or conjoined pairs. Occasionally, a visible pangkon is used.

Stacked consonants and conjoined pairs span word boundaries.

Syllable-initial clusters use 3 dedicated combining marks for the second consonant.

Word-final consonant sounds may be represented by 4 dedicated combining marks. Otherwise, if nothing follows, they are ordinary consonants followed by a visible [U+A9C0 JAVANESE PANGKON].

The Javanese orthography has 2 inherent vowels, and represents vowels using 5 vowel-signs (including 1 prescript). All vowel-signs are combining marks, and are stored after the base character. It is mandatory for 2 of the consonant+vowel sequences to be written using vocalics, rather than vowel-signs.

Independent vowels are used for standalone vowel sounds when there is a need to distinguish normal words from proper nouns or foreign words. The normal approach for standalone vowels is to apply vowel-signs to [U+A9B2 JAVANESE LETTER HA].

Only one composite vowel is used in modern Javanese orthography, although more exist when writing Sanskrit or Kawi in this script. There are no circumgraphs. The composite vowel used in modern Javanese involves only 2 vowel-signs, and places glyphs on either side of the base consonant(s).

Javanese has vocalics.

Character index



Basic consonants


Murda consonants


Mahaprana consonants


Independent vowels





Not used for modern Javanese


Combining marks




Medial consonants


Final consonants




Not used for modern Javanese







Items to show in lists


Root words are typically disyllables of the form Cˡ V Cˡ V Cˡ, where Cˡ represents an optional consonant or consonant cluster, and V represents a vowel. Most commonly, this represents CVCVC, followed by CVCCVC.c

A Javanese phonetic syllable can begin with a vowel, a consonant, or a consonant cluster.

Syllable-initial consonant clusters usually have either r or j in the second position, or may have both.

According to Comrie, word-initial consonant clusters may involve prenasalised sounds such as mb, nd, ndh, nj or nng, which appear to be written using unconnected consonants side by side,c eg. ꦩꦧꦸꦫꦸ

Syllable-final consonants are usually a single sound.

In the orthography, phonetic syllable boundaries don't always coincide with the typographic units used. See segmentation for details.


These are sounds for the Javanese language.

Click on the sounds to see where else in the document they are referred to.

Sounds in parentheses are non-native or allophones. Source Wikipedia.

Vowel sounds

i ɨ u ɪ ʊ e o ə ə ɛ ɔ a

i u e o are pronounced ɪ ʊ ɛ ɔ, respectively in closed syllables.wl,#Vowels

e and o are pronounced ɛ and ɔ, respectively, in open syllables when followed by one of i u. Otherwise they may be pronounced ə.wl,#Vowels

In the standard dialect of Surakarta, a is pronounced ɔ in word-final open syllables.wl,#Vowels

Diphthongs ai and aw are not used in modern,#Swara

Consonant sounds

labial dental alveolar post-
retroflex palatal velar glottal
stops p b t d     ʈ ɖ   k g ʔ
affricates       t͡ʃ        
aspirated       t͡ʃʰ        
fricatives     s         h
nasals m   n     ɲ ŋ
approximants w   l     j  
trills/flaps     r    

Most sources (eg. Daniels) imply that the voiced plosives are voicedd. Comriec describes the voiceless plosives as virtually unaspirated, and that the voiced plosives are devoiced at the end of a word. Wikipedia says that the Javanese "voiced" phonemes are in fact voiced voiceless, with breathy voice on the following vowel, the difference being described as stiff voice versus slack voice.wl,#Consonants Here we use the more common transcription.

The sound ʔ appears between words ending with a and the suffix ake, eg. lunga+ake -> lungaʔake.c


Vowel sounds mapped to characters

This section maps Javanese vowel sounds to common graphemes in the Javanese orthography, grouped by open ( o ), or closed ( c ), syllables, or as a standalone vowel ( s ). Click on a grapheme to find other mentions on this page (links appear at the bottom of the page). Click on the character name to see examples and for detailed descriptions of the character(s) shown.

Standalone vowels normally use the vowel-sign over a silent [U+A9B2 JAVANESE LETTER HA]. These are not shown here, but independent vowels are. Vowel-signs that decompose are shown only in precomposed form.

Plain vowels


Inherent vowel

Sources: Wikipedia.

Inherent vowels

There are two possible inherent vowel sounds: a and ɔ. The choice of inherent vowel can depend on the speaker's dialect: speakers of Western Javanese dialects tend to pronounce the inherent vowel as a, while those of Eastern Javanese prefer ɔ.ws,#Form So ka/kɔ is written by simply using the consonant letter [U+A98F JAVANESE LETTER KA].

Wikipedia describes the following rules by Wewaton Sriwedari for determining the inherent vowel of a letter:ws,#Form


Non-inherent vowel sounds that follow a consonant can be represented using vowel-signs, eg. ki is written ꦏꦶ [U+A98F JAVANESE LETTER KA + U+A9B6 JAVANESE VOWEL SIGN WULU].

An orthography that uses vowel-signs is different from one that uses simple diacritics or letters for vowels in that the vowel-signs are generally attached to the syllable, rather than just applied to the letter of the immediately preceding consonant. This means that pre-base vowel-signs and the left glyph of circumgraphs appear before a whole consonant cluster if the cluster is rendered as a conjunct (see prescript_vowels).

Javanese vowel-signs are all combining characters. All vowel-signs are stored after the base consonant. Only one is displayed before the base, and there are no circumgraphs – unlike Balinese, composite vowels are always written using multiple combining mark characters. All vowel-signs are typed and stored after the base consonant, and the font puts them in the correct place for display.

About half of the vowel-signs are spacing marks, meaning that they consume horizontal space when added to a base consonant.

Combining marks used for vowels

Javanese uses the following dedicated combining marks for vowels. They may be used on their own, or in combination with others (see composite_vowels).


Additional information about archaic forms and variants of these characters and others mentioned below can be found in the character notes document.

[U+A9B4 JAVANESE VOWEL SIGN TARUNG​] was originally a length mark, but in modern Javanese it is only used in the combination described in the section composite_vowels.

Modern Javanese doesn't write the sounds and using the consonant+vowel combinations *ꦫꦼ [U+A9AB JAVANESE LETTER RA + U+A9BC JAVANESE VOWEL SIGN PEPET] or *ꦭꦼ [U+A9AD JAVANESE LETTER LA + U+A9BC JAVANESE VOWEL SIGN PEPET]. Vocalic letters are used instead,ws,#Swara eg. ꦊꦩꦃꦊꦩ꧀ꦧꦸꦠ꧀

When a vowel-sign follows a subjoined consonant it appears above the stack.

The word kanthi, where the i appears above the n.

Four more vowel-signs are not used in modern Javanese.


See also vocalics.

Pre-base vowel-sign

One vowel-sign appears to the left of the base consonant letter or cluster in modern Javanese, eg. ꦱꦼꦏꦺꦴꦭꦃ

This is a combining mark that is always stored after the base consonant. The font places the glyph before the base consonant.

A similar vowel-sign is no longer used.

Composite vowel


In Javanese, unlike many other scripts, including Balinese, when a vowel is represented by multiple glyphs either side of a base character two separate combining marks need to be added to the base. Javanese has no circumgraphs (ie. a single code point that places glyphs around the base).

Only one such composite is used for modern Javanese, ꦺꦴ [U+A9BA JAVANESE VOWEL SIGN TALING + U+A9B4 JAVANESE VOWEL SIGN TARUNG], which represents the sound o. Both characters are typed and stored after the base character, and should be in the order shown.

The sound ko is written with three characters.

A two-part vowel associated with a consonant cluster appears before and after the whole cluster, whether it is conjoined or stacked. This is a reminder that vowel-signs are applied to the orthographic syllable, rather than to a single letter. In fig_vs_conjoined this actually extends across a word boundary, since the last and first letters of the adjoining words form a conjunct cluster. This means that the pre-base part of the vowel-sign appears to be within the previous word.

The o surrounds the ns in mangan soto.

A number of archaic vowels are also represented by combinations of the basic vowel-signs, but are not used in modern Javanese.

Show details about vowel glyph positioning.

The following list shows where vowel-signs are positioned around a base consonant to produce vowels, and how many instances of that pattern there are. The figure after the + sign represents combinations of Unicode characters,

  • 2 prescript, eg. ꦏꦺ ke
  • 2 postscript, eg. ꦏꦴ
  • 3 superscript, eg. ꦏꦶ ki
  • 2 subscript, eg. ꦏꦸ ku
  • +2 pre+postscript, eg. ꦏꦺꦴ keː

Standalone vowels

Javanese has two ways to represent standalone vowels.



The normal approach combines a vowel sign with [U+A9B2 JAVANESE LETTER HA], eg. ꦧꦲꦸꦱꦱ꧀ꦠꦿ ꦩꦲꦺꦴꦱ꧀

Without a vowel-sign the letter [U+A9B2 JAVANESE LETTER HA] represents a, eg. ꦲꦕꦫ

However, it may alternatively represent the sound ha. The reading is ambiguous, eg. compare the previous example with this: ꦲꦤꦕꦫꦏ

The same applies for other combinations of this base letter and vowel-sign.

Independent vowels


There are 8 independent vowel letters in the Javanese block, of which 5 are used in modern text.

The independent vowel letters are used in Javanese to distinguish proper nouns or foreign words from ordinary wordsu, eg. compare the following two words, which include an adjective and a personal name (both have the same pronunciation): ꦲꦪꦸ ꦄꦪꦸ

Other forms

Modern Javanese only uses short vowels. Other characters or sequences of characters were used for long vowels and diphthongs in the past or for other languages.

ꦇ␣ꦅ␣ꦈꦴ␣ꦄꦴ␣ ␣ꦍ␣ꦎꦴ

Three of the above use [U+A9B4 JAVANESE VOWEL SIGN TARUNG​] to produce long sounds.

Unlike Javanese, Kawi uses [U+A985 JAVANESE LETTER I KAWI] and [U+A986 JAVANESE LETTER I] for short and long, respectively.d

Vowel absence

Where no letter follows a consonant and the vowel is silent, for example at the end of a sentence or isolated word or before a number, a visible [U+A9C0 JAVANESE PANGKON] is used to indicate that the inherent vowel is suppressed, eg. the following explicitly represents just the sound k: ꦏ꧀

The pangkon is also used to produce conjunct forms for consonant clusters (stacking or conjoined shapes), in which case it is invisible (see clusters). Because Javanese commonly combines the last character of one word and the first of another into a conjunct, the pangkon is often not visible after words that end with a consonant within a sentence.

A visible pangkon at the end of a word.

There are some exceptions, especially where the pangkon may be used to disambiguate words, eg. ꦧꦶꦱ꧀ꦠꦿꦤ꧀​ꦱ꧀ꦗꦏꦂꦠ

No pangkon is needed between an onset consonant and a medial consonant, or after a dedicated final consonant.

Vocalic letters


These characters are treated as vowels in other scripts, such as Balinese, but as consonants in Javanese.

They represent the sounds and . Javanese doesn't use the consonant+vowel combinations *ꦫꦼ [U+A9AB JAVANESE LETTER RA + U+A9BC JAVANESE VOWEL SIGN PEPET] or *ꦭꦼ [U+A9AD JAVANESE LETTER LA + U+A9BC JAVANESE VOWEL SIGN PEPET] for those sounds,d but uses these vocalic letters instead, ws,#Swara eg. ꦊꦩꦃꦊꦩ꧀ꦧꦸꦠ꧀

Javanese vocalics have no corresponding vowel-signs. They do, however, have conjoined forms, used in consonant clusters.

Archaic forms

Two more vocalic letters or sequences are not used in modern Javanese, but are used for writing Kawi and,#Swara



Consonant sounds to characters

This section maps Javanese consonant sounds to common graphemes in the Javanese orthography, grouped by native Javanese letters ( b ), murda ( M ), or mahaprana derived forms ( m ), or extended with cecak telu ( e ). Click on a grapheme to find other mentions on this page (links appear at the bottom of the page). Click on the character name to see examples and for detailed descriptions of the character(s) shown.






Basic (nglegéna) consonants

Only 20 of the consonants in the Javanese Unicode block are used for pure Javanese language text. Some others (murda) are used as a kind of uppercase letter, but the remainder are used for words derived from Sanskrit or Kawi, or are archaic forms.

The characters listed here and in the following sections also have conjoined and/or subjoined forms, which may differ significantly from those shown here. See clusters for a list of glyph shapes.


[U+A9B2 JAVANESE LETTER HA] represents either ha or the standalone vowel a

Murda letters

Murda forms can be viewed as a kind of capital letter for proper nouns (not sentence initial letters), used as honorifics. They are used to replace an ordinary letter form in the first syllable of the name. However, not all letters have a murda form, so if there is no letter in the first syllable that has a murda form, one is used for the next syllable in the name that has one.

Highly respected names may be all 'capitalized' to the extent that the corresponding murda are available.


[U+A996 JAVANESE LETTER CA MURDA] is only attested as a subjoined form, ꧀ꦖ The non-subjoined forms shown in this paragraph and the above list are a modern-day,#Wyanjana

[U+A9AF JAVANESE LETTER SA MURDA] is a rare letter which, when used with other characters, represents the Chinese sound se, ie. ꦯ͜ꦌ̈ Another represents the Chinese syo, ie. ꦯ꦳ꦾꦺꦴ

[U+A9AC JAVANESE LETTER RA AGUNG] not used in modern text, and also not widely known, was used historically by some writers to address royal,#Wyanjana

Mahaprana letters

These are letters that are not basic forms, nor are repurposed as murda consonants.


Mahaprana forms were originally aspirated consonants used in Sanskrit and Kawi transliterations (mahaprana means aspirated). They are rarely, if ever, found in modern text.

Repertoire extension

The following combinations, called aksara rékan (ꦲꦏ꧀ꦱꦫꦫꦺꦏꦤ꧀), are used to represent foreign sounds. There may be some variance around which combinations produce which,#R%C3%A9kan

Javanese uses [U+A9B3 JAVANESE SIGN CECAK TELU] with a similar consonant to represent most foriegn sounds, initially those from Arabic, but then also those from Dutch, Indonesian, and English.


[U+A990 JAVANESE LETTER KA SASAK] is used for writing q in Sasak.

When consonants are subjoined there can be some ambiguity about which consonant the cecak telu applies to. For example, the following look identical:ꦏ꦳꧀ꦗ kˑ͓ʤ kza ꦏ꧀ꦗ꦳ k͓ʤˑ xja

Wikipedia has a set of Chinese sounds that are represented using some combining characters from a non-Javanese,#Additional_Aksara

Onset consonants

Three dedicated combining characters represent medial consonants (wyanjana), making it easy to tell that the consonant is part of a syllable-initial cluster and not the start of a new syllable.


Examples of use include ꦥꦿꦩꦸꦏ ꦏꦾꦲꦶꦏꦤ꧀ꦗꦼꦁ ky̆hikn͓ʤəŋ̽ kyai kanjeng ꦕꦕꦶꦁꦏꦽꦩꦶ ʧʧiŋ̽kr̥̆mi cacing kremi

Balinese doesn't have these dedicated medial consonants.

Final consonants

Word-final consonant sounds with no following consonant may be represented by ordinary consonant characters, followed by a visible [U+A9C0 JAVANESE PANGKON] character, eg. ꦏꦿꦸꦥꦸꦏ꧀ ꦏꦔꦼꦤ꧀

If another word or consonant does follow the word-final consonant, the pangkon is still used, but becomes invisible and results in the stacking of the two consonants. (See clusters.)

However, there is also a set of dedicated combining characters (seisigeg) that dispense with the need for the pangkan.

Four syllable-final consonant sounds are represented using combining characters.


Examples: ꦱꦼꦏꦺꦴꦭꦃ ꦥꦼꦫꦲꦸꦭꦪꦂ ꦥꦼꦠꦼꦁ

Consonant clusters

The absence of a vowel sound after a letter (ie. not involving medial or final consonant diacritics) is shown visually in the script in one of the following ways:

  1. Stacked consonants, where the non-initial (subjoined) consonant appears below the initial, often with a different shape from normal.
  2. Conjoined consonants, where consonants sit side-by-side but the non-initial consonant has a slightly different form than usual.
  3. A visible pangkon following the initial consonant.
  4. A dedicated final consonant mark followed by a regular consonant.
  5. A regular initial consonant followed by a dedicated medial consonant mark.

Word boundaries. Conjuncts span word boundaries. Because there are no spaces between words, consonants with no following vowel at the end of one word and a consonant at the beginning of the next create a cluster.

Stacks and conjoined sequences are not normally split at line ends (see word and linebreak for the ramifications of this). It means that some words cannot be wrapped at word boundaries.

In the sequence hak-hak-kang-pa-da the combination k-h is conjoined, and k-k is stacked.

Conjunct formation

See a table of 2-consonant clusters.
The table allows you to test results for various fonts.

In Unicode, the stacking and conjoining behaviour is achieved by adding [U+A9C0 JAVANESE PANGKON​] between the consonants. The font hides the glyph automatically when a stacked conjunct is formed. However, in some cases the glyph needs to remain visible.


To represent consonants without intervening vowels, the non-initial consonant is typically drawn below the initial consonant.

Many of the subjoined forms are just slightly smaller versions of the original, some with small additions, but several have very different shapes altogether, most of which ligate with the cluster initial consonant by joining strokes. 

This list shows consonants in their normal and subjoined forms

basic (nglegéna) glyphs
murda glyphs
mahaprana glyphs

Conjoined consonants

In conjoined clusters, the consonant glyphs remain side by side, but the non-initial consonant is reduced on the left side. fig_conjoined_p shows an example in the word ꦱꦩ꧀ꦥꦸꦤ꧀.

The left side of [U+A9A5 JAVANESE LETTER PA] is reduced when conjoined.

This list shows consonants in their normal and conjoined forms

basic (nglegéna) glyphs
murda glyphs
mahaprana glyphs

The conjoined [U+A9B1 JAVANESE LETTER SA] is unusual in that it also adds a glyph (resembling the vowel-sign [U+A9B8 JAVANESE VOWEL SIGN SUKU]) below the initial consonant. This helps distinguish it from the conjoined p. See fig_conjoined_p for an example in the word ꦲꦏ꧀ꦱꦫ.

[U+A9B1 JAVANESE LETTER SA] when conjoined not only loses some of its left side but also adds a glyph below the initial consonant.

Visible pangkon

Occasionally [U+A9C0 JAVANESE PANGKON​] may be visible in the middle of a word, eg. ꦧꦶꦱ꧀ꦠꦿꦤ꧀​ꦱ꧀ꦗꦏꦂꦠ

The Javanese section of the Unicode Standard doesn't indicate how to force the pangkon to remain visible, but the Balinese section recommends the use of [U+200C ZERO WIDTH NON-JOINER] (ZWNJ) after the adeg-adeg in order to prevent conjunct formation. However, not many people understand the function of ZWNJ or can access it easily from the keypad. It also doesn't introduce line-break opportunities. A better solution may be to use [U+200B ZERO WIDTH SPACE] (ZWSP). This character is needed anyway on most systems in order to allow line-breaking, and it appears to work equally well for this.

Dedicated medial & final marks

Javanese represents some final consonants using dedicated marks. There are also dedicated marks for medial consonants. Such marks are preceded and/or followed by ordinary consonant shapes in consonant clusters. There is no visual indication of missing vowel sounds other than the use of the mark itself.

A cluster involving a dedicated final mark doesn't form a conjunct.
(Word shown is ꦣꦂꦩ.)

Numbers, dates, currency, etc.

Javanese uses native digits, which are decimal-based and used in the same way as European numerals.

Pada pangkat used to indicate numbers.

Several of the digits are identical to letters of the alphabet, so [U+A9C7 JAVANESE PADA PANGKAT] is often used around numbers, eg. ꧇꧑꧕꧇ꦎꦏ꧀ꦠꦺꦴꦧꦼꦂ꧇꧒꧐꧑꧒꧇

Everson, on the other hand, says that [U+A9C8 JAVANESE PADA LINGSA] is used for this purpose, and gives the examples 6 8 9 and 2007 shown below:e ꧈꧖꧈꧘꧈꧙꧈ ꧈꧒꧐꧐꧗꧈

Text direction

Javanese script is written horiztonally, left to right.

Show default bidi_class properties for characters in the Javanese orthography described here.

Glyph shaping & positioning

This section brings together information about the following topics: writing styles; cursive text; context-based shaping; context-based positioning; baselines, line height, etc.; font styles; case & other character transforms.

You can experiment with examples using the Javanese character app.

Javanese text is not cursive (ie. joined up), however there is a significant amount of interaction between glyphs, and some joining, around consonant clusters.

The orthography has no case distinction, and no special transforms are needed to convert between characters.

Context-based shaping & positioning


Glyph shaping is required for Javanese. One principle area is that of subjoined or postfixed consonants, which often interact typographically with the preceding consonant.

Not all fonts show the same shaping behaviours.

In fig_k_joins, the three syllables, each containing a k-k stack, show how the font adapts the subjoined [U+A98F JAVANESE LETTER KA] at the bottom right according to what follows it.

 ꦏ꧀ꦏꦿ  ꦏ꧀ꦏ ꦏ꧀ꦏꦾ
Adaptations of the lower right of a subjoined k.

The following two syllables show how the font changes the shape of ꦿ [U+A9BF JAVANESE CONSONANT SIGN CAKRA​] to match the depth of the syllable.

ꦏꦿ ꦏ꧀ꦏꦿ
Adaptations of medial RA shape to suit the context.

The fig_ku_shaping the font shows different renderings of the u vowel-sign after the second character in a consonant cluster. In kru the lines suggest that the medial r is drawn after the u, although it is pronounced the other way around.

ꦏ꧀ꦏꦸ  ꦏ꧀ꦰꦸ  ꦏꦿꦸ
Adaptations of -u in kku, ksu, and kru.

Note that the middle cluster contains only one u character. The similar-looking shape in the middle of the word is just part of the kS conjoined shape. The rightmost cluster uses a ligature for -ru, where the chakra appears to be drawn after the u, although actually stored before it.

Context-based positioning

Obviously the principle of subjoining consonants requires rules about positioning, and those rules need to be disregarded for combinations where the second character of a cluster is not subjoined (though it usually changes shape).

In the following example we see ka with cecak telu on the left. In the middle syllable cecak telu has shifted slightly to the left to make room for the other diacritic. In the right-hand syllable the cecak telu has both moved and reduced in size to fit with the other diacritic.

ꦏ꦳ ꦏ꦳ꦂ ꦏ꦳ꦼ

The position and size of cecak telu depends on its neighbours.

Another example of the need for special positioning occurs when a vowel-sign is pronounced after a subjoined consonant but appears above the previous consonant in the stack (see the example earlier).

Font styles

Observation: Numerous examples of slanted text exist in the publication Kajawen in 1933. However, they are used to distinguish blocks of text from other blocks, but not inline.

Examples of use include separate panels floated alongside the main flow of text (the whole panel is slanted), subheadings or sometimes headings, figure captions, and by-lines.

Alternate lines in this text are slanted. (Click to enlarge.)

Text segmentation

Javanese doesn't use word boundaries for text segmentation, relying instead on grapheme boundaries (sometimes called orthographic syllables).

Phrase, sentence, and section delimiters are described in phrase.

Grapheme boundaries

Typographically, the basic unit of Javanese text is a grapheme whose boundaries may differ from those of the phonetic syllable.

Basic typographic units

(Base (Cecak_telu)* Pangkon)* Base (Combining_mark)*

A simple typographic unit for Javanese includes a base and any combining marks associated with it.

The base is generally a consonant, however independent vowels and occasionally numbers also constitute a base (and by some reports may be followed by combining marks).

In the case of Javanese, sequences that include a syllable nucleus may include the following combining marks:

  1. cecak telu (a kind of nukta)
  2. medial consonant
  3. vowel-sign
  4. final consonant marks

The following examples show simple typographic units that begin with a single consonant or independent vowel:


Because stacked or conjoined forms are never split apart visually, they are incorporated whole into the beginning of a typographic unit. These represent consonant clusters, which can arise where one phonetic syllable ends in a consonant letter and the following syllable begins with a consonant. The consonants that make up the cluster are all encoded with a following pangkon (see clusters).

Javanese is also unusual in that these conjuncts occur across word boundaries, so the word-final consonant of the first word may be stacked above the word-initial consonant of the second. See fig_pangandika for an example.

The following examples show typographic units that begin with a consonant cluster:


Syllable codas, as we have just seen, may be represented by a combining mark, or may be incorporated into a consonant cluster, but they may also be written using a sequence of consonant letter (possibly including a cecak telu) followed by a pangkon, which is visible if no base immediately follows it, eg.


If another consonant does follow this, the coda becomes part of a new conjunct and therefore of a new typographic unit.

On the infrequent occasions when a pangkon needs to be visible even though it is followed by another base, an invisible character must be added to prevent it joining with the following base. A zero-width space can achieve that.

Grapheme clusters. This kind of typographic unit cannot be realised using Unicode grapheme clusters because they create breaks after a pangkon, rather than including the following consonants. The following shows the segmentation that would be produced when using grapheme clusters.


Observation: Browsers based on the Gecko engine (Firefox, etc.) use grapheme clusters for cursor movement and forward delete, whereas Blink (Chrome) and WebKit (Safari) browsers use the tyographic units described here.

Code point sequences

The following indicates the expected ordering of Unicode characters within a typographic unit for Javanese. The labels are those used for the Unicode Indic Syllabic Categories. Follow that link to see what characters are represented by a given label.

Typographic Unit := (Consonant Nukta* Virama)*
                    Consonant Nukta*

                 := Vowel_Independent

                 := Consonant Nukta*

It is reported that the independent vowels and numbers may be followed by combining characters.

When multiple dependent vowels appear, they should be in the following order:


When multiple medials appear, they should be in the following order:

Bottom_And_Left || Bottom

Ordering characters as shown above avoids potential ambiguities and maximises the likelihood of success when rendering the text.

Word boundaries

Words are not separated by spaces. (Though spaces may be used to separate phrases, see phrase).

As mentioned in the previous section, Javanese is one of a small number of scripts where an initial consonant for a word may be subjoined below the last consonant of a preceding word. Since stacks are never broken, typographic operations such as line-breaking therefore split the text at orthographic syllable boundaries rather than words (see graphemes).

When the word ꦥꦔꦤ pŋn paŋan is followed by ꦢꦶꦏ dik dika, the initial letter of dika is subjoined below the last letter of paŋan, and the vowel-sign in dika appears above the stack.

Punctuation & inline features

Phrase & section boundaries


U+0020 SPACE






section Ditto.
general divider [U+A9CA JAVANESE PADA ADEG] 

If the final word in a phrase ends with ◌꧀ [U+A9C0 JAVANESE PANGKON​], a space alone is sufficient to indicate a phrase boundary. Otherwise, [U+A9C8 JAVANESE PADA LINGSA] is used.

[U+A9C7 JAVANESE PADA PANGKAT] is equivalent to a colon.

The sequence ꧀꧈ [U+A9C0 JAVANESE PANGKON + U+A9C8 JAVANESE PADA LINGSA] indicates a sentence boundary. If there is no pangkon, [U+A9C9 JAVANESE PADA LUNGSI] is used.

All of the above punctuation marks are optionally followed by a space, if they occur inside a paragraph.

A paragraph and or a section typically begins with [U+A9CB JAVANESE PADA ADEG ADEG]. This punctutation is also used before other short runs of text, such as subtitles, list items, etc.

[U+A9CA JAVANESE PADA ADEG] is a general divider. See also quotations.

A paragraph containing almost all of the punctuation marks described here.



Letters may begin with ꧋꧆꧋ if the writer doesn't want to indicate a distinction regarding age or rank between themselves and the reader. Otherwise, for more formal letters, they can choose one of three alternatives provided as single characters in the Javanese Unicode block.

The end of a letter can be signaled using ꧉꧆꧉ This combination may also involve just ꧆꧉or may be repeated with spaces between to fill the linee, eg.
꧉ ꧆ ꧉ ꧆ ꧉ ꧆ ꧉



In poetry ꧅ꦧ꧀ꦖ꧅ or ꧅ꦧ꧀ꦕ꧅ (purwapada) introduces a poem; ꧅ꦟ꧀ꦢꦿ꧅ (madyapada) introduces a new song within a poem; and ꧅ꦆ꧅ (wasanapada) indicates the end of a poem.

Optionally, [U+A9C9 JAVANESE PADA LUNGSI] can be added to the above with some space around it. The spaces should be non-breaking, since there should be no line-breaks between the constituent partse, eg.
꧅ ꧉ ꦧ꧀ꦖ ꧉ ꧅



Titles may be marked by a pair of rerenggan characters, ie. ꧁...꧂ The glyphs for these characters may vary substantially.

Parentheses & brackets

  start end






Typically a pair of [U+A9CA JAVANESE PADA ADEG] characters are used.

Alternatively, the pair of characters [U+A9CC JAVANESE PADA PISELEH] and [U+A9CD JAVANESE TURNED PADA PISELEH] may be used.


  start end
top level






As for parentheses, Javanese text may use [U+A9CA JAVANESE PADA ADEG] for quotation marks.

Alternatively, the pair of characters [U+A9CC JAVANESE PADA PISELEH] and [U+A9CD JAVANESE TURNED PADA PISELEH] may be used.



To draw attention to text Javanese may use the same characters as are used for parentheses and quotations, ie. a paired set of [U+A9CA JAVANESE PADA ADEG] characters around the relevant text, or the two characters [U+A9CC JAVANESE PADA PISELEH] and [U+A9CD JAVANESE TURNED PADA PISELEH] can be used similarly.

Sometimes just [U+A9CC JAVANESE PADA PISELEH] is repeated.

Other inline ranges


Text spacing


Abbreviation, ellipsis & repetition



According to Everson [U+A9C8 JAVANESE PADA LINGSA] is used for acronyms, eg. ꧈ꦢꦺ꧈ꦲ꧈ꦌꦭ꧀꧈

It is also used after initials in a name,e eg. ꦫ꧈ꦩ꧈ꦯꦸꦭꦂꦠ


A repeated syllable can be represented by [U+A9CF JAVANESE PANGRANGKEP], which is derived from the arabic-indic digit for 2, eg. ꦧꦸꦏꦸꧏ buku-buku books It can be transcribed as buku2.

For 'ditto' marks in vertical lists, Javanese uses [U+A9C9 JAVANESE PADA LUNGSI] .

Inline notes & annotations


Correction marks

According to Wikipedia [U+A9DF JAVANESE PADA ISEN-ISEN] is used in handwriting to indicate a correction in Yogyakarta, eg. where a scribe wanted to write pada luhur but actually wrote pada wu.. they would use this mark as follows: ꦥꦢꦮꦸ꧟꧟꧟ꦭꦸꦲꦸꦂ

In Yogyakarta they would use the character [U+A9DE JAVANESE PADA TIRTA TUMETES] instead.

Other punctuation


Line & paragraph layout

Line breaking & hyphenation

Like Tibetan, line breaking can occur after any full orthographic syllable, however no conjuncts are split during line breaking.

Observation: Does a 'full' orthographic syllable include a syllable coda written as a normal consonant letter followed by pangkon? Does that need to be wrapped with the syllable onset and nucleus?

Because there are no spaces between words, and because the end of one word and the beginning of another often form conjuncts (see fig_pangandika), Javanese doesn't wrap at word boundaries. Instead, it wraps at syllable boundaries where no conjuncts are involved.

Unfortunately, modern browsers are often unable to detect appropriate break points for Javanese. In the sample text at the beginning of this page ZWSP [U+200B ZERO WIDTH SPACE] is used at places where the line could be broken. Otherwise, the line would continue, unbroken off the right side of the page.

Show (default) line-breaking properties for characters in the modern Javanese orthography.

Hyphenation, per se, is not used. See an interesting discussion about Javanese & Balinese line-breaking on GitHub.

Taling duplication

In some materials, when a new line begins with [U+A9BA JAVANESE VOWEL SIGN TALING], an additional spacing taling is placed at the end of the previous line.

An extra taling at the end of the line when the word kawon is split before won.

In online use, an application would need to create the extra taling, rather than the content author. As line-length is changed by stretching a window, or as content is added earlier in the same paragraph, the location of the word relative to the line edge will change. The insertion of an extra taling is only appropriate at those instants when the taling happens to appear at the line start.

Text alignment & justification

Observation: Articles in the Kajawen publication are fully justified. The justification algorithm appears to stretch spaces, which generally occur on each line, and also to slightly stretch inter-character spaces. In the latter case, stacks and super-/subscript diacritics are not affected, but space is added between prescript vowel-signs and base characters, and between base characters and conjoined characters.

Paragraph indents

Observation: One of the articles in the Kajawen publication uses paragraph indents. See an example.

Counters, lists, etc.


Styling initials


Baselines & inline alignment


Page & book layout

This section is for any features that are specific to Javanese and that relate to the following topics: general page layout & progression; grids & tables; notes, footnotes, etc; forms & user interaction; page numbering, running headers, etc.

Online resources

  1. Universal Declaration of Human Rights - Javanese (Javanese)
  2. Kajawen 1933-08-26