1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
---
title: ':dir()'
slug: 'Web/CSS/:dir'
translation_of: 'Web/CSS/:dir'
---
<div>{{CSSRef}}{{SeeCompatTable}}</div>
<p><strong><code>:dir()</code></strong> — это <a href="/en-US/docs/Web/CSS/Pseudo-classes">псевдокласс</a> <a href="/en-US/docs/Web/CSS">CSS</a>, который выбирает элементы на основе направления текста в них.</p>
<pre class="brush: css no-line-numbers">/* Выбирает все элементы с текстом справа-налево */
:dir(rtl) {
background-color: red;
}</pre>
<p><code>:dir()</code> учитывает только <em>семантическое </em>направление, т.е. заданное в самом документе. Он не учитывает <em>стилизованное </em>направление, т.е. заданное CSS-правилами, например {{cssxref("direction")}}.</p>
<div class="note">
<p><strong>Примечание:</strong> помните о том, что псевдокласс <code>:dir()</code> <strong>не эквивалентен</strong> <a href="/ru/docs/Web/CSS/Attribute_selectors">выбору по атрибуту</a> <code>[dir=…]</code>. Последний применяется только к тем элементам HTML, у которых есть атрибут {{htmlattrxref("dir")}}, игнорируя те, у которых он не задан — даже если они унаследовали его значение. (Похожим образом <code>[dir=rtl]</code> и<code>[dir=ltr]</code> не будут включать <code>auto</code>.) <code>:dir()</code>, же, напротив, соответствует значению вычисленному {{glossary("user agent")}}, даже унаследованному.</p>
</div>
<div class="note">
<p><strong>Примечание:</strong> В HTML, направление задаётся атрибутом {{htmlattrxref("dir")}}. В других форматах могут использоваться иные методы.</p>
</div>
<h2 id="Синтаксис">Синтаксис</h2>
<p><code>:dir()</code> требует одного параметра, представляющего желаемое направление.</p>
<h3 id="Parameters">Parameters</h3>
<dl>
<dt><code>ltr</code></dt>
<dd>Выбирает элементы с направлением текста слева-направо.</dd>
<dt><code>rtl</code></dt>
<dd>Выбирает элементы с направлением текста справа-налево.</dd>
</dl>
<h3 id="Formal_syntax">Formal syntax</h3>
{{csssyntax}}
<h2 id="Пример">Пример</h2>
<h3 id="HTML">HTML</h3>
<pre class="brush:html;"><div dir="rtl">
<span>test1</span>
<div dir="ltr">test2
<div dir="auto">עִבְרִית</div>
</div>
</div>
</pre>
<h3 id="CSS">CSS</h3>
<pre class="brush: css">:dir(ltr) {
background-color: yellow;
}
:dir(rtl) {
background-color: powderblue;
}</pre>
<h3 id="Result">Result</h3>
<p>{{ EmbedLiveSample('Пример') }}</p>
<h2 id="Спецификации">Спецификации</h2>
<table class="standard-table">
<thead>
<tr>
<th scope="col">Specification</th>
<th scope="col">Status</th>
<th scope="col">Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{SpecName('HTML WHATWG', 'scripting.html#selector-ltr', ':dir(ltr)')}}</td>
<td>{{Spec2('HTML WHATWG')}}</td>
<td>No changes.</td>
</tr>
<tr>
<td>{{SpecName('CSS4 Selectors', '#the-dir-pseudo', ':dir()')}}</td>
<td>{{Spec2('CSS4 Selectors')}}</td>
<td>Initial definition.</td>
</tr>
</tbody>
</table>
<h2 id="Совместимость_с_браузерами">Совместимость с браузерами</h2>
<div>
<p>{{Compat("css.selectors.dir")}}</p>
</div>
<h2 id="Смотрите_также">Смотрите также</h2>
<ul>
<li>Языково-специфичные селекторы CSS: {{cssxref(":lang")}}, {{cssxref(":dir")}}</li>
</ul>
|