मैं तीन कॉलम के साथ एक फ्लेक्सबॉक्स लेआउट सेट अप करने का प्रयास कर रहा हूं। बाएं और दाएं कॉलम की एक निश्चित चौड़ाई है। केंद्र कॉलम में उपलब्ध स्थान को भरने के लिए तरल चौड़ाई है, लेकिन इसमें एक लंबा टेक्स्ट होता है, जिसे लपेटा नहीं जाना चाहिए और इसके बजाय इलिप्सिस का उपयोग करना चाहिए।फ्लेक्सबॉक्स - "नो रैप" टेक्स्ट के साथ द्रव कॉलम
दुर्भाग्य से, गैर-लिपटे पाठ कॉलम के लिए उपलब्ध स्थान लेने की क्षमता प्रदान नहीं करता है और पूरे लेआउट को मूल तत्व की सीमाओं से परे धक्का देता है।
img {
max-width: 100%;
}
#container {
display: flex;
max-width: 900px;
}
.column.left {
width: 350px;
flex: 0 0 350px;
}
.column.right {
width: 350px;
flex: 0 0 350px;
}
.column.center {
// fluid width required
}
h1 {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
<div id="container">
<div class="column left">
<img src="https://placeholdit.imgix.net/~text?txtsize=33&txt=350%C3%97150&w=350&h=150" alt="">
</div>
<div class="column center">
<h1>
This is long text. If overflow use ellipsis
</h1>
</div>
<div class="column right">
<img src="https://placeholdit.imgix.net/~text?txtsize=33&txt=350%C3%97150&w=350&h=150" alt="">
</div>
</div>
लिंक बेला के लिए: http://jsfiddle.net/2Lp8d80n/
किसी भी मदद की सराहना की है।
आप सुझाव के रूप में, आप सीएसएस संपत्ति 'फ्लेक्स-आधार का उपयोग कर सकते 0 0 350px;' दोनों को छोड़ दिया और सही स्तंभों में। ':)' – Ricky
@ रिकार्डोरुइज़, यदि आप 'flex' के बजाय 'flex-base' का उपयोग करते हैं, तो' flex-shrink 'डिफ़ॉल्ट रूप से' 1' पर उपयोग करता है। लेकिन ओपी चाहता है 'फ्लेक्स-सिकंक: 0'। जैसा कि spec अनुशंसा करता है, प्रारंभिक मानों को ओवरराइड करने के लिए 'flex' प्रॉपर्टी का उपयोग करना बेहतर है। * देखें 'फ्लेक्स-सिकंक' कारक * यहां: http://stackoverflow.com/a/34355447/3597276 –