الفرق بين المراجعتين لصفحة: «CSS/align-items»
لا ملخص تعديل |
لا ملخص تعديل |
||
(4 مراجعات متوسطة بواسطة مستخدمين اثنين آخرين غير معروضة) | |||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE:الخاصية <code>align-items</code>}}</noinclude> | <noinclude>{{DISPLAYTITLE:الخاصية <code>align-items</code>}}</noinclude> | ||
الخاصية <code>align-items</code> في CSS تُعرِّف طريقة توزيع المتصفح للمسافة بين العناصر وحولها على امتداد المحور الثانوي من حاوية flex. فهي تعمل كالخاصية <code>[[CSS/justify-content|justify-content]]</code> لكن في الاتجاه المعامد.<syntaxhighlight lang="css"> | الخاصية <code>align-items</code> في CSS تُعرِّف طريقة توزيع المتصفح للمسافة بين العناصر وحولها على امتداد المحور الثانوي من حاوية flex. فهي تعمل كالخاصية <code>[[CSS/justify-content|justify-content]]</code> لكن في الاتجاه المعامد. | ||
== بطاقة الخاصية == | |||
{| class="wikitable" style="width: 100%;" | |||
|- | |||
! scope="row" style="width: 20%;" |[[CSS/initial value|القيمة الابتدائية]] | |||
|<code>stretch</code> | |||
|- | |||
! scope="row" |تُطبَّق على | |||
|حاويات flex. | |||
|- | |||
! scope="row" |قابلة للوراثة | |||
|لا | |||
|- | |||
!قابلة للتحريك | |||
|لا | |||
|- | |||
! scope="row" |القيمة المحسوبة | |||
|كما حُدِّدَت. | |||
|}<syntaxhighlight lang="css"> | |||
/* الكلمات المحجوزة الأساسية */ | /* الكلمات المحجوزة الأساسية */ | ||
align-items: normal; | align-items: normal; | ||
سطر 31: | سطر 52: | ||
قد يصعب فهم الشرح السابق دون توفير مثال، لذا سنقارن في المثال الحي الآتي بين الخاصيتين: | قد يصعب فهم الشرح السابق دون توفير مثال، لذا سنقارن في المثال الحي الآتي بين الخاصيتين: | ||
<div dir="ltr" style="border: 1px solid #eaecf0; background-color: #f8f9fa; margin: 1em; padding: 1em;"><code>align-content: center;</code><div style="display:flex;flex-wrap:wrap;height:200px;width:240px;background-color:#8c8c8c;align-content:center;"><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffa0;min-height:30px;">1</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#a0c8ff;min-height:50px;">2</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffa08c;min-height:40px;">3</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffff8c;min-height:60px;">4</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ff8cff;min-height:70px;">5</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffff;min-height:50px;font-size:30px;">6</div></div><br><code>align-items: center;</code><div style="display:flex;flex-wrap:wrap;height:200px;width:240px;background-color:#8c8c8c;align-items:center;"><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffa0;min-height:30px;">1</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#a0c8ff;min-height:50px;">2</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffa08c;min-height:40px;">3</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffff8c;min-height:60px;">4</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ff8cff;min-height:70px;">5</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffff;min-height:50px;font-size:30px;">6</div></div></div> | <div dir="ltr" style="border: 1px solid #eaecf0; background-color: #f8f9fa; margin: 1em; padding: 1em;"><code>align-content: center;</code><div style="display:flex;flex-wrap:wrap;height:200px;width:240px;background-color:#8c8c8c;align-content:center;"><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffa0;min-height:30px;">1</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#a0c8ff;min-height:50px;">2</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffa08c;min-height:40px;">3</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffff8c;min-height:60px;">4</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ff8cff;min-height:70px;">5</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffff;min-height:50px;font-size:30px;">6</div></div><br><code>align-items: center;</code><div style="display:flex;flex-wrap:wrap;height:200px;width:240px;background-color:#8c8c8c;align-items:center;"><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffa0;min-height:30px;">1</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#a0c8ff;min-height:50px;">2</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffa08c;min-height:40px;">3</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ffff8c;min-height:60px;">4</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#ff8cff;min-height:70px;">5</div><div style="box-sizing:border-box;border-width:2px;border-style:solid;border-color:#8c8c8c;width:50px;display:flex;align-items:center;justify-content:center;background-color:#8cffff;min-height:50px;font-size:30px;">6</div></div></div> | ||
== أمثلة == | == أمثلة == | ||
سطر 203: | سطر 204: | ||
تقبل الخاصية <code>align-items</code> القيم التالية، لاحظ أنَّنا لم نشرح القيم غير المدعومة إلا في قلّة من المتصفحات لعدم جدوى ذلك. | تقبل الخاصية <code>align-items</code> القيم التالية، لاحظ أنَّنا لم نشرح القيم غير المدعومة إلا في قلّة من المتصفحات لعدم جدوى ذلك. | ||
=== | === <code>flex-start</code> === | ||
ستتم محاذاة العناصر بجوار بعضها بدءًا من بداية المحور الثانوي لحاوية flex (أي من أعلى العنصر في أغلبية الحالات). | ستتم محاذاة العناصر بجوار بعضها بدءًا من بداية المحور الثانوي لحاوية flex (أي من أعلى العنصر في أغلبية الحالات). | ||
=== | === <code>flex-end</code> === | ||
ستتم محاذاة العناصر بجوار بعضها بدءًا من نهاية المحور الثانوي لحاوية flex (أي من أسفل العنصر في أغلبية الحالات). | ستتم محاذاة العناصر بجوار بعضها بدءًا من نهاية المحور الثانوي لحاوية flex (أي من أسفل العنصر في أغلبية الحالات). | ||
=== | === <code>center</code> === | ||
ستتم محاذاة العناصر بجوار بعضها بدءًا من وسط المحور الثانوي لحاوية flex. | ستتم محاذاة العناصر بجوار بعضها بدءًا من وسط المحور الثانوي لحاوية flex. | ||
=== | === <code>stretch</code> === | ||
إذا كانت أبعاد العناصر الموجودة داخل الحاوية على المحور الثانوي أقل من أبعاد الحاوية، فستزيد أبعاد العناصر زيادةً متساويةً لكن مع احترام القيود المفروضة عبر خاصيات <code>[[CSS/max-height|max-height]]</code> أو <code>[[CSS/max-width|max-width]]</code> (أو ما شابه ذلك)، وبالتالي ستكون أبعاد العناصر الموجودة داخل الحاوية تساوي بُعد الحاوية على المحور الثانوي. | إذا كانت أبعاد العناصر الموجودة داخل الحاوية على المحور الثانوي أقل من أبعاد الحاوية، فستزيد أبعاد العناصر زيادةً متساويةً لكن مع احترام القيود المفروضة عبر خاصيات <code>[[CSS/max-height|max-height]]</code> أو <code>[[CSS/max-width|max-width]]</code> (أو ما شابه ذلك)، وبالتالي ستكون أبعاد العناصر الموجودة داخل الحاوية تساوي بُعد الحاوية على المحور الثانوي. | ||
سطر 219: | سطر 220: | ||
align-items: flex-start | flex-end | center | stretch; | align-items: flex-start | flex-end | center | stretch; | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== انظر أيضًا == | |||
* صفحة الخاصيات الفرعية التي تضبطها الخاصية align وهي:<code>[[CSS/align-content|align-content]]</code>، و <code>[[CSS/align-self|align-self]]</code>. | |||
* صفحة الخاصية <code>[[CSS/position|position]]</code> التي تصف كيف يجب أن يتموضع العنصر في المستند. | |||
* صفحة كل من الخاصيات <code>[[CSS/width|width]]</code>، و <code>[[CSS/bottom|height]]</code> المسؤولة عن تحديد أبعاد العنصر. | |||
== مصادر ومواصفات == | == مصادر ومواصفات == | ||
* مسودة [https://drafts.csswg.org/css-align/#propdef-align-items CSS Box Alignment Module Level 3]، أضافت هذه المسودة القيم <code>baseline</code> و <code>first baseline</code> و <code>last baseline</code> و <code>self-start</code> و <code>self-end</code> و <code>start</code> و <code>end</code> و <code>left</code> و <code>right</code> و <code>unsafe</code> و <code>safe</code>؛ لكن دعم هذه القيم ما يزال ضعيفًا. | * مسودة [https://drafts.csswg.org/css-align/#propdef-align-items CSS Box Alignment Module Level 3]، أضافت هذه المسودة القيم <code>baseline</code> و <code>first baseline</code> و <code>last baseline</code> و <code>self-start</code> و <code>self-end</code> و <code>start</code> و <code>end</code> و <code>left</code> و <code>right</code> و <code>unsafe</code> و <code>safe</code>؛ لكن دعم هذه القيم ما يزال ضعيفًا. | ||
* مواصفة [https://drafts.csswg.org/css-flexbox-1/#propdef-align-items CSS Flexible Box Layout Module]. | * مواصفة [https://drafts.csswg.org/css-flexbox-1/#propdef-align-items CSS Flexible Box Layout Module]. | ||
[[تصنيف:CSS]] | [[تصنيف:CSS|{{SUBPAGENAME}}]] | ||
[[تصنيف:CSS Property]] | [[تصنيف:CSS Property|{{SUBPAGENAME}}]] | ||
[[تصنيف:CSS Flexbox]] | [[تصنيف:CSS Flexbox|{{SUBPAGENAME}}]] |
المراجعة الحالية بتاريخ 19:48، 24 يوليو 2018
الخاصية align-items
في CSS تُعرِّف طريقة توزيع المتصفح للمسافة بين العناصر وحولها على امتداد المحور الثانوي من حاوية flex. فهي تعمل كالخاصية justify-content
لكن في الاتجاه المعامد.
بطاقة الخاصية
القيمة الابتدائية | stretch
|
---|---|
تُطبَّق على | حاويات flex. |
قابلة للوراثة | لا |
قابلة للتحريك | لا |
القيمة المحسوبة | كما حُدِّدَت. |
/* الكلمات المحجوزة الأساسية */
align-items: normal;
align-items: stretch;
/* المحاذاة المكانية */
align-items: center;
align-items: start;
align-items: end;
align-items: flex-start;
align-items: flex-end;
align-items: self-start;
align-items: self-end;
align-items: left;
align-items: right;
/* محاذاة خط الأساس */
align-items: baseline;
align-items: first baseline;
align-items: last baseline;
align-items: safe center;
align-items: unsafe center;
/* القيم العامة */
align-items: inherit;
align-items: initial;
align-items: unset;
الفرق بين هذه الخاصية والخاصية align-content
هو أنَّه هذه الخاصية تُحدِّد محاذاة العناصر اعتمادًا على خط المحاذاة، بينما الخاصية align-content
تُحدِّد محاذاة الخطوط نفسها.
قد يصعب فهم الشرح السابق دون توفير مثال، لذا سنقارن في المثال الحي الآتي بين الخاصيتين:
align-content: center;
align-items: center;
أمثلة
مثال عن استخدام جميع القيم المدعومة في أغلبية المتصفحات حاليًا، لاحظ طريقة توزيع العناصر والمسافات الفارغة المتروكة حولها عند استخدام مختلف القيم:
<code>align-items: flex-start;</code>
<div class="container flex-start">
<div id="item1">1</div>
<div id="item2">2</div>
<div id="item3">3</div>
<div id="item4">4</div>
<div id="item5">5</div>
<div id="item6">6</div>
</div>
<br>
<code>align-items: flex-end;</code>
<div class="container flex-end">
<div id="item1">1</div>
<div id="item2">2</div>
<div id="item3">3</div>
<div id="item4">4</div>
<div id="item5">5</div>
<div id="item6">6</div>
</div>
<br>
<code>align-items: center;</code>
<div class="container center">
<div id="item1">1</div>
<div id="item2">2</div>
<div id="item3">3</div>
<div id="item4">4</div>
<div id="item5">5</div>
<div id="item6">6</div>
</div>
<br>
<code>align-items: stretch;</code>
<div class="container stretch">
<div id="item1">1</div>
<div id="item2">2</div>
<div id="item3">3</div>
<div id="item4">4</div>
<div id="item5">5</div>
<div id="item6">6</div>
</div>
شيفرة CSS:
.container {
display: flex;
flex-wrap: wrap;
height:200px;
width: 240px;
background-color: #8c8c8c;
}
.flex-start { align-items: flex-start; }
.flex-end { align-items: flex-end; }
.center { align-items: center; }
.stretch { align-items: stretch; }
div > div {
box-sizing: border-box;
border: 2px solid #8c8c8c;
width: 50px;
display: flex;
justify-content: center;
}
#item1 {
background-color: #8cffa0;
min-height: 30px;
}
#item2 {
background-color: #a0c8ff;
min-height: 50px;
}
#item3 {
background-color: #ffa08c;
min-height: 40px;
}
#item4 {
background-color: #ffff8c;
min-height: 60px;
}
#item5 {
background-color: #ff8cff;
min-height: 70px;
}
#item6 {
background-color: #8cffff;
min-height: 50px;
font-size: 30px;
}
دعم المتصفحات
الميزة | Chrome | Firefox | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
الدعم الأساسي | 29.0 | 20.0 | 11 | 12.5 | 9.0 |
start و end | غير مدعومة | مدعومة | غير مدعومة | غير مدعومة | ؟ |
left و right | غير مدعومة | 52.0 | غير مدعومة | غير مدعومة | ؟ |
baseline | 57.0 | مدعومة | غير مدعومة | 44.0 | ؟ |
first baseline و last baseline | غير مدعومة | 52.0 | غير مدعومة | غير مدعومة | ؟ |
stretch | 57.0 | 52.0 | غير مدعومة | 44.0 | ؟ |
الإصدارات القديمة من بعض المتصفحات (مثل Chrome و IE و Safari) كانت تدعم flexbox لكن مع استخدام سابقة (-webkit-
أو -ms-
).
البنية العامة
تقبل الخاصية align-items
القيم التالية، لاحظ أنَّنا لم نشرح القيم غير المدعومة إلا في قلّة من المتصفحات لعدم جدوى ذلك.
flex-start
ستتم محاذاة العناصر بجوار بعضها بدءًا من بداية المحور الثانوي لحاوية flex (أي من أعلى العنصر في أغلبية الحالات).
flex-end
ستتم محاذاة العناصر بجوار بعضها بدءًا من نهاية المحور الثانوي لحاوية flex (أي من أسفل العنصر في أغلبية الحالات).
center
ستتم محاذاة العناصر بجوار بعضها بدءًا من وسط المحور الثانوي لحاوية flex.
stretch
إذا كانت أبعاد العناصر الموجودة داخل الحاوية على المحور الثانوي أقل من أبعاد الحاوية، فستزيد أبعاد العناصر زيادةً متساويةً لكن مع احترام القيود المفروضة عبر خاصيات max-height
أو max-width
(أو ما شابه ذلك)، وبالتالي ستكون أبعاد العناصر الموجودة داخل الحاوية تساوي بُعد الحاوية على المحور الثانوي.
البنية الرسمية
align-items: flex-start | flex-end | center | stretch;
انظر أيضًا
- صفحة الخاصيات الفرعية التي تضبطها الخاصية align وهي:
align-content
، وalign-self
. - صفحة الخاصية
position
التي تصف كيف يجب أن يتموضع العنصر في المستند. - صفحة كل من الخاصيات
width
، وheight
المسؤولة عن تحديد أبعاد العنصر.
مصادر ومواصفات
- مسودة CSS Box Alignment Module Level 3، أضافت هذه المسودة القيم
baseline
وfirst baseline
وlast baseline
وself-start
وself-end
وstart
وend
وleft
وright
وunsafe
وsafe
؛ لكن دعم هذه القيم ما يزال ضعيفًا. - مواصفة CSS Flexible Box Layout Module.