成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

flex布局踩過的那些坑

劉玉平 / 2926人閱讀

摘要:接下來說說我踩過的那些坑布局版本兼容問題布局自提出之后,變化過好幾個版本標志標志標志新增了對項的規(guī)定草案階段兼容方案父級布局不用考慮其他屬性都對應(yīng)相關(guān)的版本方案,目前項目中是只寫最新的方案,由自動添加兼容方案。

接觸H5項目后,開始了解到flex布局,功能非常之強大,用起來相當之舒服?;镜闹R介紹就不說了,參考http://www.ruanyifeng.com/blo...。

接下來說說我踩過的那些坑:

1.flex布局版本兼容問題

flex布局自2009提出之后,變化過好幾個版本:

**2009** version
標志:**display: box**; 

**2011** version
標志:**display: flexbox**; 

**2012** version
標志:**display: flex/inline-flex**; 

2014 version
新增了對flex項z-index的規(guī)定

2015 W3C Editor’s Draft
(草案階段)

兼容方案:
父級flex布局

display: -webkit-box;   /* OLD - iOS 6-, Safari 3.1-6 */
display: -moz-box;  /* OLD - Firefox 19- H5不用考慮 */
display: -mz-flexbox; /* TWEENER IE 10 */
display: flex; /* NEW, Spec - Opera 12.1, Firefox 20+ */

其他屬性都對應(yīng)相關(guān)的版本方案,目前項目中是只寫最新的方案,由autoprefixer自動添加兼容方案。

2.關(guān)于flex-grow的寬度分配問題

flex-grow屬性用于設(shè)置或檢索彈性盒的擴展比率,默認為0。不允許為負值。
最為常見的用法是用flex-grow實現(xiàn)等比例“tab”布局,舉例:

元素 元素 元素 元素
元素
元素

css:

.box {
    display: flex;
    align-items: center;
    padding: 40px 20px;
    color: white;
    background-color: black;
}
.item {
    flex-grow: 1;
    height: 60px;
    line-height: 60px;
    text-align: center;
    border: 1px solid white;
    background-color: #ff0000;
}

不用害怕浮動,不用考慮子元素是塊級元素還是行內(nèi)元素,顯示OK,不管外面flex父級寬度如何變化,它們都等比分布:

糾正一下自己錯誤的理解,flex-grow是分配flex容器除內(nèi)容外剩余空間的比例,并不是整個容器的比例[捂臉],所以出現(xiàn)下面的現(xiàn)象是完全正常的,雖然解決方案可行,但我依然不懂其中的緣由,再次[捂臉]。。。

氮素,“意外”來了:

好奇怪,怎么不是等比例顯示?大家flex-grow都是1,為什么你要占那么寬?
最后找到解決方案,所有flex-grow的子元素加上flex-basis: 0%;就是完全等比分布了,這個屬性值會讓父級主軸在計算剩余空間時忽略子元素的本身寬度,從而實現(xiàn)等比分配。簡單寫法就是直接定義flex: 1;不分開定義三個屬性。當然如果是那種連串的英文就要設(shè)置word-break: break-all;。

3.設(shè)置了flex-grow元素的子級寬度問題

來,栗子:

Hi
一個flex-grow為1的元素的子級一個flex-grow為1的元素的子級一個flex-grow 為1的元素的子級一個flex-grow為1的元素的子級

css:

.box {
    display: flex;
    align-items: center;
    padding: 40px 20px;
    color: white;
    background-color: black;
}

.item {
    flex-grow: 1;
    width: 100%;
    height: 60px;
    line-height: 60px;
    text-align: center;
    background-color: #ff0000;
}

.text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.other {
    flex-shrink: 0;
    display: inline-block;
    width: 150px;
    height: 60px;
    line-height: 60px;
    background-color: orange;
}

大跌眼鏡的事就這么發(fā)生了,flex-grow元素的子級居然撐破了父級的寬度,超出去了,不知道該怎么解釋這種現(xiàn)象:

解決方案就是,flex-grow元素設(shè)置overflow: hidden;效果:

最后一個小坑,算不上坑,就是父級設(shè)置了flex布局后,子元素就算是行內(nèi)元素很多瀏覽器可以把它當做inline-block或者block元素來用,可以直接設(shè)置它的寬高,但是還是有些瀏覽器不支持,所以要設(shè)置行內(nèi)元素的寬度,還是手動設(shè)置一下它的display為inline-block或者block.

flex布局非常好用,就是PC兼容性相對較差,IE要10,甚至11以上才有很好的兼容,不過大家可以用它在H5頁面好好發(fā)揮。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/111436.html

相關(guān)文章

  • 【echarts3】 折線圖我過的那些 (tooltip 設(shè)置,line 單個點/散點不顯示問題

    摘要:折線圖小技巧折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線為主,對大家完成一些曲線和的展示及交互有所幫助基本使用文檔寫得非常詳細清晰,官方示例也很豐富,中還有很多功能更強大的示例篇的是很 echarts 折線圖小技巧 echarts 折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線...

    isaced 評論0 收藏0
  • 【echarts3】 折線圖我過的那些 (tooltip 設(shè)置,line 單個點/散點不顯示問題

    摘要:折線圖小技巧折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線為主,對大家完成一些曲線和的展示及交互有所幫助基本使用文檔寫得非常詳細清晰,官方示例也很豐富,中還有很多功能更強大的示例篇的是很 echarts 折線圖小技巧 echarts 折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線...

    MonoLog 評論0 收藏0
  • Docker初體驗——過的那些

    摘要:原因其實這個報錯不需要下載最新文件,而是文件沒有放到正確的位置。重啟電腦后按或進入界面不同主板型號進入所需按鍵不同。端口映射環(huán)境下可能不存在這個問題坑在下部署了應(yīng)用服務(wù)并進行了端口映射。 2018?年?3?月?6?日 Docker安裝 環(huán)境:windows7 安裝包:DockerToolbox-17.10.0-ce.exe (下載地址:http://mirrors.aliyun.co...

    Jrain 評論0 收藏0
  • 那些年我們過的亂碼

    摘要:因此導(dǎo)致亂碼的真正原因就是各平臺間對標準實現(xiàn)不一致包括實現(xiàn)的時間先后不同,以及所代表含義不同。日本幾家公司各自定義了一套標準,用兩個字節(jié)表示符號,日本電腦系統(tǒng)的一種編碼編碼是從到。在上找到了與標準的對應(yīng)關(guān)系。 歡迎關(guān)注個人網(wǎng)站:http://www.iamaddy.net/2016/07/emoji-unicode-parser/ 前言 這是一個由亂碼引發(fā)的故事。抱歉我暫時找不到更加慘...

    jhhfft 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<