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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
|
---
title: justify-self
slug: Web/CSS/justify-self
tags:
- CSS
- CSS属性
- CSS盒对齐
translation_of: Web/CSS/justify-self
---
<div>{{CSSRef}}</div>
<p><a href="/en-US/docs/Web/CSS">CSS</a> <strong><code>justify-self</code></strong> 属性设置单个盒子在其布局容器适当轴中的对其方式。</p>
<div>{{EmbedInteractiveExample("pages/css/justify-self.html")}}</div>
<p>此属性的效果取决于我们所处的布局模式:</p>
<ul>
<li>在块级布局中,它对齐一个项目在其包含块的内联轴上。</li>
<li>对于绝对定位的元素,它对齐一个项目在其包含块的内联轴上,同时计算top,left,bottom与right的值。(原文:it aligns an item inside its containing block on the inline axis, accounting for the offset values of top, left, bottom, and right.)</li>
<li>在表格布局中,这个属性被忽略(<a href="/en-US/docs/Web/CSS/CSS_Box_Alignment/Box_Alignment_In_Block_Abspos_Tables">更多</a> 关于块、绝对定位以及表格布局中的对齐方式)</li>
<li>在弹性布局中,这个属性被忽略(<a href="/en-US/docs/Web/CSS/CSS_Box_Alignment/Box_Alignment_in_Flexbox">更对</a> 关于弹性布局中的对齐方式)</li>
<li>在栅格布局中,它对齐一个元素到该元素所在的栅格区域的内联轴上。(<a href="/en-US/docs/Web/CSS/CSS_Box_Alignment/Box_Alignment_In_Grid_Layout">更多</a> 关于栅格布局中的对齐方式)</li>
</ul>
<h2 id="语法">语法</h2>
<pre class="brush:css no-line-numbers notranslate">/* 基础关键字 */
justify-self: auto;
justify-self: normal;
justify-self: stretch;
/* 位置对齐 */
justify-self: center; /* 在中间放置元素 */
justify-self: start; /* 在开始处放置元素 */
justify-self: end; /* 在结束处放置元素 */
justify-self: flex-start; /* 与 'start' 等效。注意 justify-self 在 Flexbox 布局中被忽略。 */
justify-self: flex-end; /* 与 'end' 等效。注意 justify-self 在 Flexbox 布局中被忽略。 */
justify-self: self-start;
justify-self: self-end;
justify-self: left; /* 在左侧放置元素 */
justify-self: right; /* 在右侧放置元素 */
/* 基线对齐 */
justify-self: baseline;
justify-self: first baseline;
justify-self: last baseline;
/* 溢出对齐 (只对位置对齐有效果)*/
justify-self: safe center;
justify-self: unsafe center;
/* 全局关键字 */
justify-self: inherit;
justify-self: initial;
justify-self: unset;
</pre>
<p>这个属性可以有三种不同的形式:</p>
<ul>
<li>基本关键字: <code>normal</code>, <code>auto</code>,或者 <code>stretch</code>。</li>
<li>基线对齐:<code>baseline</code> 关键字,加上可选的 <code>first</code> 或者 <code>last</code>。</li>
<li>可定位对齐:
<ul>
<li><code>center</code>, <code>start</code>, <code>end</code>, <code>flex-start</code>, <code>flex-end</code>, <code>self-start</code>, <code>self-end</code>, <code>left</code>,或者 <code>right</code>。</li>
<li>加上可选的 <code>safe</code> 或者<code>unsafe</code>。</li>
</ul>
</li>
</ul>
<h3 id="Values">Values</h3>
<dl>
<dt><code>auto</code></dt>
<dd>该值使用其父级元素盒子的 <code>justify-items</code> 属性的值,除非它没有父级元素, 或者是绝对定位的,这些情况下,<code>auto</code> 代表了 <code>normal</code>。</dd>
<dt><code>normal</code></dt>
<dd>这个效果取决于我们所处的布局模式:
<ul>
<li>在块级布局中,这个关键字是 <code>start</code> 的同义词。</li>
<li>在绝对定位的布局中,在可置换绝对定位的盒子中,这个关键字表现的与 <code>start</code> 相似,在其他绝对定位的盒子中,其表现得与 <code>stretch</code> 相似。</li>
<li>在表格布局中,由于这个属性被忽略所以这个关键字没有作用。</li>
<li>在弹性布局中,由于这个属性被忽略所以这个关键字没有作用。</li>
<li>在栅格布局中,这个关键字会导致类似于 <code>stretch</code> 的行为,除了具有高宽比或固有大小的盒子,它的行为类似于 <code>start</code> 。</li>
</ul>
</dd>
<dt><code>start</code></dt>
<dd>项目被放置到适当的轴上,朝向对齐容器的起始边缘,彼此齐平。</dd>
<dt><code>end</code></dt>
<dd>项目被放置到适当的轴上,朝向对齐容器的末端边缘,彼此齐平。</dd>
<dt><code>flex-start</code></dt>
<dd>对于非弹性容器子元素的项目,这个值被视为 <code>start</code> 。</dd>
<dt><code>flex-end</code></dt>
<dd>对于非弹性容器子元素的项目,这个值被视为 <code>end</code>.</dd>
<dt><code>self-start</code></dt>
<dd>The item is packed flush to the edge of the alignment container of the start side of the item, in the appropriate axis.</dd>
<dt><code>self-end</code></dt>
<dd>The item is packed flush to the edge of the alignment container of the end side of the item, in the appropriate axis.</dd>
<dt><code>center</code></dt>
<dd>项目被放置在对齐容器的中心向彼此平齐。</dd>
<dt><code>left</code></dt>
<dd>项目在对齐容器的左边缘,并彼此对齐。如果属性的轴与内联轴不平行,则此值的行为类似于<code>start</code> 。</dd>
<dt><code>right</code></dt>
<dd>项目在对齐容器的右边缘,并彼此对齐。如果属性的轴与内联轴不平行,则此值的行为类似于 <code>start</code> 。</dd>
<dt><code>baseline<br>
first baseline</code><br>
<code>last baseline</code></dt>
<dd>Specifies participation in first- or last-baseline alignment: aligns the alignment baseline of the box’s first or last baseline set with the corresponding baseline in the shared first or last baseline set of all the boxes in its baseline-sharing group.<br>
The fallback alignment for <code>first baseline</code> is <code>start</code>, the one for <code>last baseline</code> is <code>end</code>.</dd>
<dt><code>stretch</code></dt>
<dd>If the combined size of the items is less than the size of the alignment container, any <code>auto</code>-sized items have their size increased equally (not proportionally), while still respecting the constraints imposed by {{CSSxRef("max-height")}}/{{CSSxRef("max-width")}} (or equivalent functionality), so that the combined size exactly fills the alignment container.</dd>
<dt><code>safe</code></dt>
<dd>If the size of the item overflows the alignment container, the item is instead aligned as if the alignment mode were <code>start</code>.</dd>
<dt><code>unsafe</code></dt>
<dd>Regardless of the relative sizes of the item and alignment container, the given alignment value is honored.</dd>
</dl>
<h2 id="形式化定义">形式化定义</h2>
<p>{{cssinfo}}</p>
<h2 id="形式化语法">形式化语法</h2>
{{csssyntax}}
<h2 id="例子">例子</h2>
<h3 id="简单演示">简单演示</h3>
<p>In the following example we have a simple 2 x 2 grid layout. Initially the grid container is given a <code>justify-items</code> value of <code>stretch</code> — the default — which causes the grid items to stretch across the entire width of their cells.</p>
<p>The second, third, and fourth grid items are then given different values of <code>justify-self</code>, to show how these override the <code>justify-items</code> value. These values cause the grid items to span only as wide as their content width, and align in different positions across their cells.</p>
<h4 id="HTML">HTML</h4>
<pre class="brush: html notranslate"><article class="container">
<span>First child</span>
<span>Second child</span>
<span>Third child</span>
<span>Fourth child</span>
</article></pre>
<h4 id="CSS">CSS</h4>
<pre class="brush: css notranslate">html {
font-family: helvetica, arial, sans-serif;
letter-spacing: 1px;
}
article {
background-color: red;
display: grid;
grid-template-columns: 1fr 1fr;
grid-auto-rows: 40px;
grid-gap: 10px;
width: 300px;
justify-items: stretch;
}
span:nth-child(2) {
justify-self: start;
}
span:nth-child(3) {
justify-self: center;
}
span:nth-child(4) {
justify-self: end;
}
article span {
background-color: black;
color: white;
margin: 1px;
text-align: center;
}
article, span {
padding: 10px;
border-radius: 7px;
}
article {
margin: 20px;
}</pre>
<h4 id="结果">结果</h4>
<p>{{EmbedLiveSample('Simple_demonstration', '100%', 200)}}</p>
<h2 id="标准">标准</h2>
<table class="standard-table">
<thead>
<tr>
<th>Specification</th>
<th>Status</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{SpecName("CSS3 Box Alignment", "#propdef-justify-self", "justify-self")}}</td>
<td>{{Spec2("CSS3 Box Alignment")}}</td>
<td>Initial definition</td>
</tr>
</tbody>
</table>
<h2 id="浏览器兼容性">浏览器兼容性</h2>
<h3 id="弹性布局中的支持">弹性布局中的支持</h3>
<p>{{Compat("css.properties.justify-self.flex_context")}}</p>
<h3 id="栅格布局中的支持">栅格布局中的支持</h3>
<p>{{Compat("css.properties.justify-self.grid_context")}}</p>
<h2 id="参考">参考</h2>
<ul>
<li>CSS Grid Guide: <em><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Box_Alignment_in_CSS_Grid_Layout">Box alignment in CSS Grid layouts</a></em></li>
<li><a href="/en-US/docs/Web/CSS/CSS_Box_Alignment">CSS Box Alignment</a></li>
<li>The {{CSSxRef("justify-items")}} property</li>
</ul>
|