摘要:當到了某個標簽不能被完全展示下時則不顯示。可以看出來最后兩個由于會超出的寬度,被折到了下一行,然后又被的隱藏。
首發于本人的博客 varnull.cn
遇到一個需求,需要實現的樣式是固定寬度的容器里一排顯示若干個標簽,數量不定,每個標簽的長度也不定。當到了某個標簽不能被完全展示下時則不顯示。大致效果如下,標簽只顯示一排,多了放不下了就不顯示了。
標簽部分 DOM 結構如下
Cooking Coding Travel Photography Reading
乍一看這個問題很簡單嘛,本著樣式問題盡量不用 js 解決的原則,寫了下面這堆樣式,完美實現效果。可以看出來最后兩個 .label 由于會超出 .labels 的寬度,被折到了下一行,然后又被 .labels 的 overflow: hidden 隱藏。
.label { display: block; height: 24px; line-height: 24px; padding: 0 10px; background-color: #e1ecf4; border-radius: 12px; font-size: 14px; flex-shrink: 0; // label 不收縮,長度為內容長度 & + .label { margin-left: 5px; } } .labels { height: 24px; // 一行 label 的高度 overflow: hidden; display: flex; flex-wrap: wrap; justify-content: flex-start; }
但是剛高興沒多久,突然發現了問題,如果第一個標簽的長度就超出了容器的寬度的話,并不會被整個隱藏,只是內容被截斷了,像下面這樣
這個問題困擾了我好一陣時間,一直在想 css 里有什么屬性可以在子元素寬度超過父容器時把它整個隱藏(而非僅僅隱藏超出父容器的部分)。各種思索都沒有結果正準備放棄萬分糾結到底用不用 js 實現時,突然冒出來一個想法 ==既然現在被折行的元素可以被隱藏掉,那讓第一個標簽也折行不就行了嘛==。
那么怎么讓第一個標簽折行呢,想到一個比較 trick 的方法,讓它不再是第一個元素就可以利用 flex 的特性把它折行了~ 于是,在所有 .label 元素之前,添加了一個 .placeholder 元素只有 1px 寬,高度為 100%。
Inspect 元素的話可以看到確實 .placeholder 元素占據了第一行的位置,實現了我們想要的效果~
其實利用這個想法,使用 float 也可以實現同樣的效果。雖然有點 trick 并且還是借助了一個額外的 DOM 元素,不過效果還是完美實現了的~ 附上 codepen 鏈接供參考 https://codepen.io/Simona_Den...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/112966.html
摘要:當到了某個標簽不能被完全展示下時則不顯示。可以看出來最后兩個由于會超出的寬度,被折到了下一行,然后又被的隱藏。 首發于本人的博客 varnull.cn 遇到一個需求,需要實現的樣式是固定寬度的容器里一排顯示若干個標簽,數量不定,每個標簽的長度也不定。當到了某個標簽不能被完全展示下時則不顯示。大致效果如下,標簽只顯示一排,多了放不下了就不顯示了。showImg(https://segme...
摘要:原文地址本篇文章是筆者的設計指南學習筆記的第二部分,由于最近都在準備期末考的事,所以都沒來得及對設計指南進行一些總結,沒有看之前第一部分的話也可以從這里傳送過去。 原文地址:http://justclear.github.io/css-stylin-with-css-note-2 本篇文章是筆者的 《CSS 設計指南》 學習筆記的第二部分,由于最近都在準備期末考的事,所以都沒來得及對 ...
摘要:也就是說,較寬的外邊距決定兩個元素最終離多遠。盒模型結論二沒有設定屬性的元素始終會擴展到填滿其父元素的寬度為止。布局的基本概念多欄布局有三種基本的實現方案固定寬度流動彈性。 為文檔添加樣式的三種方法 行內樣式 行內樣式是寫在HTML標簽的style屬性里的,比如: Hello Everyone! 行內樣式會覆蓋嵌入樣式和鏈接樣式。 嵌入樣式 嵌入的css樣式是放在HTML文檔...
摘要:事件與節點每個瀏覽器事件處理器被注冊在上下文中。事件對象雖然目前為止我們忽略了它,事件處理器函數作為對象傳遞事件對象。若事件處理器不希望執行默認行為通常是因為已經處理了該事件,會調用事件對象的方法。 來源:ApacheCN『JavaScript 編程精解 中文第三版』翻譯項目原文:Handling Events 譯者:飛龍 協議:CC BY-NC-SA 4.0 自豪地采用谷歌翻譯 部分...
摘要:界面上的更改都是通過操作實現的,并不是通過傳統的刷新頁面實現的。操作優化的總原則是盡量減少操作。通過在文檔片段上進行操作,可以降低操作對頁面性能的影響,這種方式是創建一個文檔片段,并在此片段上進行必要的操作,操作完成后將它附加在頁面中。 界面上UI的更改都是通過DOM操作實現的,并不是通過傳統的刷新頁面實現 的。盡管DOM提供了豐富接口供外部調用,但DOM操作的代價很高,頁面前端代碼的...
閱讀 2896·2021-11-17 09:33
閱讀 3677·2021-11-16 11:42
閱讀 3498·2021-10-26 09:50
閱讀 1353·2021-09-22 15:49
閱讀 3051·2021-08-10 09:44
閱讀 3684·2019-08-29 18:36
閱讀 3941·2019-08-29 16:43
閱讀 2231·2019-08-29 14:10