الخاصية flex-direction
الخاصية flex-direction في CSS تُعرِّف ما هو المحور الرئيسي (main axis) في حاوية flex وما اتجاهه (عادي أم معكوس).
/* اتجاه العناصر أفقي */
flex-direction: row;
/* اتجاه العناصر أفقي، لكن بالمقلوب */
flex-direction: row-reverse;
/* اتجاه العناصر رأسي */
flex-direction: column;
/* اتجاه العناصر رأسي، لكن بالمقلوب */
flex-direction: column-reverse;
/* القيم العامة */
flex-direction: inherit;
flex-direction: initial;
flex-direction: unset;
لاحظ أنَّ القيمتين row و row-reverse تتأثران باتجاه حاوية flex، فلو كانت الخاصية dir مضبوطةً إلى ltr (أي من اليسار إلى اليمين، كما في اللغة الإنكليزية)، فستمثِّل القيمة row المحور الأفقي باتجاه من اليسار إلى اليمين، و row-reverse ستمثِّل المحور الأفقي باتجاه من اليمين إلى اليسار؛ أما لو كانت قيمة dir تساوي rtl (أي من اليمين إلى اليسار، كما في اللغة العربية)، فستمثِّل row المحور الأفقي المتجه من اليمين إلى اليسار، والقيمة row-reverse ستُمثِّله لكن من اليسار إلى اليمين.
| القيمة الابتدائية | row
|
|---|---|
| تُطبَّق على | حاويات flex. |
| قابلة للوراثة | لا |
| قابلة للتحريك | لا |
| القيمة المحسوبة | كما حُدِّدَت. |
أمثلة
مثال عن استخدام الخاصية flex-direction لضبط المحور الرئيسي وضبط اتجاهه، ويبيّن استعمال الكلمات المحجوزة row و row-reverse و column و column-reverse:
<div class="grid">
<div class="col">
<div class="row">
<div class="cell">
row
<div class="container row">
<span>A</span>
<span>B</span>
<span>C</span>
</div>
</div>
<div class="cell">
row-reverse
<div class="container row-reverse">
<span>A</span>
<span>B</span>
<span>C</span>
</div>
</div>
</div>
<div class="row">
<div class="cell">
column
<div class="container column">
<span>A</span>
<span>B</span>
<span>C</span>
</div>
</div>
<div class="cell">
column-reverse
<div class="container column-reverse">
<span>A</span>
<span>B</span>
<span>C</span>
</div>
</div>
</div>
</div>
</div>
شيفرة CSS:
.grid {
width: 100%;
min-height: 100%;
display: flex;
font: 1em monospace;
}
.row {
display: flex;
flex: 1 auto;
flex-direction: row;
flex-wrap: wrap;
height: auto;
}
.col {
display: flex;
flex: 1 auto;
flex-direction: column;
height: auto;
}
.cell {
margin: .5em;
padding: .5em;
background-color: #FFF;
overflow: hidden;
text-align: center;
flex: 1 auto;
}
.container {
background: #E4F0F5;
padding: .5rem;
margin: 0 auto;
font-size: 1rem;
display:flex;
width: 11rem;
height: 11rem;
}
.container span {
display: block;
padding: 1em;
margin: .1em;
border: 1px solid black;
background: #CCC;
flex: 1;
}
.row { flex-direction: row; }
.row-reverse { flex-direction: row-reverse; }
.column { flex-direction: column; }
.column-reverse { flex-direction: column-reverse; }
دعم المتصفحات
| الميزة | Chrome | Firefox | Internet Explorer | Opera | Safari |
|---|---|---|---|---|---|
| الدعم الأساسي | 29.0 | 20.0 | 11 | 12.5 | 9.0 |
الإصدارات القديمة من بعض المتصفحات (مثل Chrome و IE و Safari) كانت تدعم flexbox لكن مع استخدام سابقة (-webkit- أو -ms-).
البنية العامة
تقبل الخاصية flex-direction قيمةً واحدةً من القيم الآتية:
القيمة row
سيكون المحور الرئيسي لحاوية flex بنفس اتجاه النص، أي من اليسار إلى اليمين إذا كانت dir تساوي ltr، ومن اليمين إلى اليسار إذا كانت dir تساوي rtl.
القيمة row-reverse
لها نفس سلوك الكلمة المحجوزة row لكن مع عكس مكان البداية والنهاية.
القيمة column
سيكون المحور الرئيسي لحاوية flex من الأعلى إلى الأسفل.
القيمة column -reverse
لها نفس سلوك الكلمة المحجوزة column لكن مع عكس مكان البداية والنهاية.
البنية الرسمية
flex-direction: row | row-reverse | column | column-reverse;
مصادر ومواصفات
- مواصفة CSS Flexible Box Layout Module.