Technique H56:Using the dir
attribute on an inline element to resolve problems
with nested directional runs
Applicability
HTML and XHTML
This technique relates to 1.3.2: Meaningful Sequence (Sufficient when used with G57: Ordering the content in a meaningful sequence).
Description
The objective of this technique is to identify changes in the text direction of text
that includes nested directional runs by providing the dir
attribute on
inline elements. A nested directional run is a run of text that includes mixed directional
text, for example, a paragraph in English containing a quoted Hebrew sentence which
in turn includes an English phrase. Use of the dir
attribute on an enclosing span
or other inline element may be necessary because the Unicode bidirectional algorithm can produce undesirable results when mixed
directional text contains spaces or punctuation. The concepts used in this technique
are described in What you need to know about the bidi algorithm and inline markup.
Examples
Example 1
This example defines the text direction of a nested, mixed-direction phrase, in Hebrew and English, to be right-to-left. Because the whole quote is in Hebrew, and therefore runs right to left, the text "W3C" and the comma should appear to the left of (i.e., after) the Hebrew text, like this:
The title is "פעילות הבינאום, W3C" in Hebrew.
Visually-ordered ASCII version (RTL text in uppercase, LTR in lower):
the title is "w3c ,YTIVITCA NOITAZILANOITANRETNI" in hebrew.
The Unicode bidirection algorithm alone is insufficient to achieve the right result, and leaves the text 'W3C' on the right side of the quote:
The title is "פעילות הבינאום, W3C" in Hebrew.
Visually-ordered ASCII version:
the title is "YTIVITCA NOITAZILANOITANRETNI, w3c" in hebrew.
The following markup will produce the expected result:
<p>The title says "<span lang="he" dir="rtl">פעילות הבינאום, W3C</span>" in Hebrew.</p>
Other sources
No endorsement implied.
Tests
Procedure
- Examine the text direction of text in the document
- If the text direction is right-to-left, check that for the ancestor element that
has a
dir
attribute, the attribute has the value "rtl" - If the text direction is left-to-right, check that there is no ancestor element
with a
dir
attribute, or that for the ancestor element that has adir
attribute, the attribute has the value "ltr"
Expected Results
- Checks #2 and #3 are true for all text.