CSS3 फ्लेक्स: बच्चे को दाईं ओर खींचें


91

यहाँ मेरे पास फिडल है

ul {
  display: flex;
  justify-content: flex-start;
  flex-direction: row;
  align-items: center;
  width: 100%;
  height: 100px;
  background: #333;
  padding: 15px;
}

ul li {
  padding: 15px;
  margin: 5px;
  background: #efefef;
  border: 1px solid #ccc;
  display: inline-block;
  list-style: none;
}

#item-1 {
  height: 50px;
}

#item-2 {
  height: 70px;
}
<ul>
  <li id="item-1">Home</li>
  <li id="item-2">Menu</li>
  <li>More</li>
  <li>Stuff</li>
  <li>Settings</li>
</ul>

मैं चाहता हूं कि फ्लेक्स-बॉक्स के अंदर अंतिम आइटम को अन्य सभी वस्तुओं को रखने के दौरान दाईं ओर ("सेटिंग" मेरी फ़िडल में) खींच दिया जाए । "सेटिंग्स" -यह भी लंबवत और सब कुछ केंद्रित होना चाहिए।

align-self: flex-end आइटम को नीचे की ओर धकेलता है (मैं इसे दाईं ओर चाहता हूं)।

मैं फ्लेक्स-बॉक्स का उपयोग कर एक समाधान को बहुत पसंद करूंगा क्योंकि मेरी वस्तुओं में परिवर्तनशील ऊंचाइयां हैं और उन्हें हमेशा लंबवत केंद्रित होना चाहिए।

इसे प्राप्त करने का सबसे साफ तरीका क्या है?

आपकी सहायताके लिए धन्यवाद!

जवाबों:


218

सरल फिक्स, एक ऑटो-एडजस्टिंग मार्जिन का उपयोग करें:

ul li:last-child {
    margin-left: auto;
}

आप यह भी उपयोग नहीं करना चाह सकते हैं width: 100%ताकि तत्व दृश्य क्षेत्र के अंदर रहे:

ul {
    display: flex;
    justify-content: flex-start;
    flex-direction: row;
    align-items: center;
    /* width: 100%; */
    height: 100px;
    background: #333;
    padding: 15px;
}

http://jsfiddle.net/dwLHE/

Https://www.w3.org/TR/css-flexbox-1/#auto-margins भी देखें

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.