blob: 501349ce96a977eb6615ca7b9f4d90d66976bd22 (
plain)
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
|
---
title: ':dir()'
slug: 'Web/CSS/:dir'
tags:
- CSS伪类
- 布局
- 网络
- 选择器4
translation_of: 'Web/CSS/:dir'
---
<p>{{ CSSRef() }}</p>
<p>{{ SeeCompatTable() }}</p>
<h2 id="总结">总结</h2>
<p><code>:dir()</code>伪类匹配特定文字书写方向的元素。在HTML中, 文字方向由{{ htmlattrxref("dir", "html") }}属性决定。其他的文档类型可能有其他定义文字方向的方法。</p>
<p>值得注意的是用CSS伪类 <code>:dir()</code> 并不等于使用 <code>[dir=…]</code> 属性选择器。后者匹配 {{ htmlattrxref("dir", "html") }} 的值且不会匹配到未定义此属性的元素,即使该元素继承了父元素的属性;类似的, <code>[dir=rtl]</code> 或 <code>[dir=ltr]不会匹配到dir属性的值为auto的元素。而</code> <code>:dir()</code>会匹配经过客户端计算后的属性, 不管是继承的dir值还是dir值为auto的。</p>
<p><span style="font-family: consolas,monaco,andale mono,monospace;">另外,:dir()伪类仅考虑文档(大多数情况是HTML)中定义的文字方向的语义值(semantic value),并不会考虑格式值(styling value),如CSS属性</span> {{ cssxref("direction") }} 的值。</p>
<h2 id="Syntax" name="Syntax">语法</h2>
<pre class="syntaxbox">元素:dir(文字书写方向) { <em>style properties</em> } 文字书写方向为ltr或rtl
</pre>
<h2 id="Examples" name="Examples">示例</h2>
<pre class="brush:html;"><div dir="rtl">
<span>test1</span>
<div dir="ltr">test2
<div dir="auto">עִבְרִית</div>
</div>
</div>
</pre>
<p>本例中 <code>:dir(rtl)</code> 会匹配最外层的div,内容为<code>test1的span,</code>和有希伯来字符的div。<code>:dir(ltr)</code> 会匹配到内容为<code>test2的div.</code></p>
<h2 id="规范">规范</h2>
<table class="standard-table">
<thead>
<tr>
<th scope="col">规范</th>
<th scope="col">状态</th>
<th scope="col">注释</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{ SpecName('CSS4 Selectors', '#the-dir-pseudo', ':dir()') }}</td>
<td>{{ Spec2('CSS4 Selectors') }}</td>
<td>最初定义.</td>
</tr>
</tbody>
</table>
<h2 id="浏览器兼容性">浏览器兼容性</h2>
{{Compat("css.selectors.dir")}}
<h2 id="Related_Pages" name="Related_Pages"> </h2>
<h2 id="Related_Pages" name="Related_Pages">参见</h2>
<ul>
<li>语言相关伪类: {{ cssxref(":lang") }}, {{ cssxref(":dir") }}</li>
</ul>
|