Inhaltsverzeichnis
1、用于父元素的样式
2、用于子元素的样式
1、子元素水平排列,按比例分割父元素宽度
2、子元素水平排列,一个子元素定宽,剩余子元素按比例分割
3、子元素垂直排列,分割父元素高度
4、子元素水平排列,定高垂直方向居中对齐
1、垂直等高,水平均分,按比例划分
2、水平居中
3、垂直居中
4、移动端弹窗 
Heim Web-Frontend HTML-Tutorial flexbox简介_html/css_WEB-ITnose

flexbox简介_html/css_WEB-ITnose

Jun 24, 2016 am 11:34 AM

一、概述

浮动在移动布局中不再重要,flex盒模型越来越重要。

flexbox经历过三个版本,主要区别是2009年到2012年之间的语法变化。最新的语法和现在规范是同步的(例display:flex和“flex-{*}”属性)。在这之间的语法是2011年出现的非官方语法,只能被IE识别(例display:flexbox;display: -ms-flexbox)。最老的语法产生于2009年(例display: box;或者“box-{*}”属性)
Nach dem Login kopieren

flexbox是css3新增盒子模型,可以实现复杂的布局。flexbox没有得到firefox,Opera,chrome浏览器的完全支持,但可以使用它们的私有属性定义firefox(-moz),opera(-o),chrome/safari(-webkit)。

flexbox经典的布局应用是垂直等高,水平均分,按比例划分。

二、flexbox常用属性

1、用于父元素的样式

  • display:block;该属性会将此元素及其直系子代加入弹性框模型中。(flexbox模型只适用于直系子代)
  • box-orient:horizontal|vertical|inline-axis|block-axis|inherit;该属性定义父元素中的子元素是如何排列的。horizontal对父元素的宽度分配划分。
  • box-pack:start|end|center|justify;box-pack表示父容器里面子容器的水平对齐方式
  • box-align:start|end|center|baseline|stretch;表示父容器里面子容器的垂直对齐方式。
  • 2、用于子元素的样式

  • box-flex:0|任意数字;该属性让子容器针对父容器的宽度按一定规则进行划分。
  • 三、快速入门demo

    1、子元素水平排列,按比例分割父元素宽度

    .parent宽度500px,其子元素水平排列,child-one占1/6,child-two占2/6,child-three占了3/6。

    <style>        .parent{            width: 500px;            height: 200px;            display: -webkit-box;            -webkit-box-orient: horizontal;/* 虽然默认的排列方式是水平的,但是为了区分起见,加上该属性 */        }        .child-one{            background: lightblue;            -webkit-box-flex: 1;        }        .child-two{            background: lightgray;            -webkit-box-flex: 2;        }        .child-three{            background: lightgreen;            -webkit-box-flex: 3;        }    </style></head><div style="display: -webkit-box;-webkit-box-pack: center;border: 1px solid #000;"><!---webkit-box-pack:center让.parent水平居中-->    <div class="parent">        <div class="child-one">1</div>        <div class="child-two">2</div>        <div class="child-three">3</div>    </div></div>
    Nach dem Login kopieren

    2、子元素水平排列,一个子元素定宽,剩余子元素按比例分割

    <style>        .parent{            width: 500px;            height: 200px;            display: -webkit-box;            background-color:pink;            -webkit-box-orient: horizontal;/* 虽然默认的排列方式是水平的,但是为了区分起见,加上该属性 */        }        .child-one{            background: lightblue;            -webkit-box-flex: 1;        }        .child-two{            background: lightgray;            -webkit-box-flex: 2;        }        .child-three{            background: lightgreen;            /*定宽,并加上左右margin,父元素加上粉色背景色更好理解*/            width:150px;            margin:0 15px;        }    </style></head><div style="display: -webkit-box;-webkit-box-pack: center;border: 1px solid #000;"><!---webkit-box-pack:center让.parent水平居中-->    <div class="parent">        <div class="child-one">1</div>        <div class="child-two">2</div>        <div class="child-three">3</div>    </div></div>
    Nach dem Login kopieren

    3、子元素垂直排列,分割父元素高度

    .parent中的子元素垂直排列,所以每个子元素宽度占100%。

    <style>        .parent{            width: 400px;            height: 600px;            display: -webkit-box;            background-color:pink;            -webkit-box-orient: vertical;/*子元素垂直排列 */        }        .child-one{            background: lightblue;            -webkit-box-flex: 1;        }        .child-two{            background: lightgray;            -webkit-box-flex: 2;        }        .child-three{            background: lightgreen;            /*定高,有上下margin,父元素加上粉色背景色更好理解*/            height:200px;            margin:15px 0;        }    </style></head><div style="display: -webkit-box;-webkit-box-pack: center;border: 1px solid #000;"><!---webkit-box-pack:center让.parent水平居中-->    <div class="parent">        <div class="child-one">1</div>        <div class="child-two">2</div>        <div class="child-three">3</div>    </div></div>
    Nach dem Login kopieren

    4、子元素水平排列,定高垂直方向居中对齐

    父元素中子元素水平排列,子元素定高时设置垂直方向对齐方式为居中对齐。

    <style>        .parent{            width: 400px;            height: 200px;            display: -webkit-box;            background-color:pink;            -webkit-box-orient: horizontal;            /*-webkit-box-align:center;/*父元素中子元素水平排列,定高时设置垂直方向对齐方式为垂直居中*/        }        .child-one{            background: lightblue;            -webkit-box-flex: 1;            height:100px;        }        .child-two{            background: lightgray;            -webkit-box-flex: 2;            height:110px;        }        .child-three{            background: lightgreen;            -webkit-box-flex: 2;            height:120px;        }    </style></head><div style="display: -webkit-box;-webkit-box-pack: center;border: 1px solid #000;"><!---webkit-box-pack:center让.parent水平居中-->    <div class="parent">        <div class="child-one">1</div>        <div class="child-two">2</div>        <div class="child-three">3</div>    </div></div>
    Nach dem Login kopieren

    四、经典布局

    flexbox经典的布局应用是垂直等高,水平均分,按比例划分,水平垂直居中,还可以实现移动端的弹窗。

    1、垂直等高,水平均分,按比例划分

    .parent{display: -webkit-box; display: -webkit-flex; display: flex;}.child{-webkit-box-flex: 1; -webkit-flex: 1; flex: 1;}
    Nach dem Login kopieren

    完整demo

    <style>    .parent{display: -webkit-box; display: -webkit-flex; display: flex;    height:100px;    width:150px;    background-color:pink;}    .child{-webkit-box-flex: 1; -webkit-flex: 1; flex: 1;    border:1px solid green;    }</style><div class="parent">  <div class="child"></div>  <div class="child"></div>  <div class="child"></div></div>
    Nach dem Login kopieren

    2、水平居中

    .parent{display: -webkit-box; display: -webkit-flex; display: flex; -webkit-box-pack: center; -webkit-justify-content: center; justify-content: center;}
    Nach dem Login kopieren

    完整demo:

    <style>    .parent{display: -webkit-box; display: -webkit-flex; display: flex; -webkit-box-pack: center;    -webkit-justify-content: center; justify-content: center;    height:100px;    width:150px;    background-color:pink;}    .child{    width:50px;    height:50px;    border:1px solid green;    }</style><div class="parent">  <div class="child"></div></div>
    Nach dem Login kopieren

    3、垂直居中

    .parent{display: -webkit-box; display: -webkit-flex; display: flex; -webkit-box-align: center; -webkit-align-items: center; align-items: center;}
    Nach dem Login kopieren

    完整demo

    <style>    .parent{display: -webkit-box; display: -webkit-flex; display: flex; -webkit-box-align: center;    -webkit-align-items: center; align-items: center;    height:100px;    width:150px;    background-color:pink;}    .child{    width:50px;    height:50px;    border:1px solid green;    }</style></head><body><div class="parent">  <div class="child"></div></div>
    Nach dem Login kopieren

    4、移动端弹窗

    现在移动端很多弹窗组件使用flexbox来实现,直接嵌套div.overlay>div.pop。

    <style>    .overlay{    /*flex style*/    display:-webkit-box;     -webkit-box-orient:horizontal;     -webkit-box-pack:center;     -webkit-box-align:center;         display:-moz-box;     -moz-box-orient:horizontal;     -moz-box-pack:center;     -moz-box-align:center;     display:-o-box;     -o-box-orient:horizontal;     -o-box-pack:center;     -o-box-align:center;     display:-ms-box;     -ms-box-orient:horizontal;     -ms-box-pack:center;     -ms-box-align:center;     display:box;     box-orient:horizontal;     box-pack:center;     box-align:center;        display: -webkit-flex;    -webkit-align-items: center;    -webkit-justify-content: center;        display: flex;    align-items: center;    justify-content: center;    /*other style*/    width:100%;    max-width:750px;    height:100%;    position:fixed;    top:0;    left:0;    background:rgba(0,0,0,0.5);    }    .popup{    width:90%;    max-width:650px;    border:1px solid green;    padding:20px 4% 4% 4%;    box-sizing:border-box;    height:auto;    background:#fff;    border-radius:4px;    position:relative;    }    .popup-close{    width:15px;    height:14px;    background:url(image/close.png) no-repeat;    background-size:100% 100%;    position:absolute;    top:8px;    right:8px;    }</style>主页面的文字<div class="overlay">  <div class="popup">  <a href="javascript:;" class="popup-close"></a>  弹层的文字  </div></div>
    Nach dem Login kopieren

    五、兼容性

     

    PC端:

  • 无前缀:Chrome 29+, Firefox 28+, IE 11+, Opera 17+
  • 需要前缀:Chrome 21+, Safari 6.1+, Opera 15+需要前缀-webkit-
  • 提示:旧版本的Firefox(22-27)支持除了flex-wrap和flex-flow之外的新语法。Opera (12.1+ - 17+)使用flex可以没有私有前缀,但是中间的15和16版本需要私有前缀。

    移动端:

  • 无前缀:Android 4.4+, Opera mobile 12.1+, BlackBerry 10+, Chrome for Android 39+, Firefox for Android 33+, IE 11+ mobile
  • 需要前缀:iOS 7.1+需要前缀-webkit-
  • 六、资源链接

    display:-webkit-box

    A Complete Guide to Flexbox

    探索Flexbox

    时下Web App中的Flexbox应用

     

    本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:有问题欢迎与我讨论,共同进步。

     

    Erklärung dieser Website
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

    Heiße KI -Werkzeuge

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    AI Hentai Generator

    AI Hentai Generator

    Erstellen Sie kostenlos Ai Hentai.

    Heißer Artikel

    R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
    4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Beste grafische Einstellungen
    4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
    4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Chat -Befehle und wie man sie benutzt
    4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

    Heiße Werkzeuge

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor

    SublimeText3 chinesische Version

    SublimeText3 chinesische Version

    Chinesische Version, sehr einfach zu bedienen

    Senden Sie Studio 13.0.1

    Senden Sie Studio 13.0.1

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    Dreamweaver CS6

    Dreamweaver CS6

    Visuelle Webentwicklungstools

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    Was ist der Zweck des & lt; Fortschritts & gt; Element? Was ist der Zweck des & lt; Fortschritts & gt; Element? Mar 21, 2025 pm 12:34 PM

    Der Artikel erörtert den HTML & lt; Progress & gt; Element, Absicht, Styling und Unterschiede vom & lt; Meter & gt; Element. Das Hauptaugenmerk liegt auf der Verwendung & lt; Fortschritt & gt; Für Aufgabenabschluss und & lt; Meter & gt; für stati

    Was ist der Zweck des & lt; datalist & gt; Element? Was ist der Zweck des & lt; datalist & gt; Element? Mar 21, 2025 pm 12:33 PM

    Der Artikel erörtert den HTML & lt; Datalist & gt; Element, das die Formulare verbessert, indem automatische Vorschläge bereitgestellt, die Benutzererfahrung verbessert und Fehler reduziert werden.Character Count: 159

    Was sind die besten Praktiken für die Kompatibilität des Cross-Browsers in HTML5? Was sind die besten Praktiken für die Kompatibilität des Cross-Browsers in HTML5? Mar 17, 2025 pm 12:20 PM

    In Artikel werden Best Practices zur Gewährleistung der HTML5-Cross-Browser-Kompatibilität erörtert und sich auf die Erkennung von Merkmalen, die progressive Verbesserung und die Testmethoden konzentriert.

    Wie verwende ich HTML5 -Formularvalidierungsattribute, um die Benutzereingabe zu validieren? Wie verwende ich HTML5 -Formularvalidierungsattribute, um die Benutzereingabe zu validieren? Mar 17, 2025 pm 12:27 PM

    In dem Artikel werden unter Verwendung von HTML5 -Formularvalidierungsattributen wie Erforderlich, Muster, Min, MAX und Längengrenzen erörtert, um die Benutzereingabe direkt im Browser zu validieren.

    Was ist der Zweck des & lt; Meter & gt; Element? Was ist der Zweck des & lt; Meter & gt; Element? Mar 21, 2025 pm 12:35 PM

    Der Artikel erörtert das HTML & lt; Meter & gt; Element, verwendet zur Anzeige von Skalar- oder Bruchwerten innerhalb eines Bereichs und seine gemeinsamen Anwendungen in der Webentwicklung. Es differenziert & lt; Meter & gt; von & lt; Fortschritt & gt; und Ex

    Was ist das Ansichtsfenster -Meta -Tag? Warum ist es wichtig für reaktionsschnelles Design? Was ist das Ansichtsfenster -Meta -Tag? Warum ist es wichtig für reaktionsschnelles Design? Mar 20, 2025 pm 05:56 PM

    In dem Artikel wird das Ansichtsfenster -Meta -Tag erörtert, das für das reaktionsschnelle Webdesign auf mobilen Geräten unerlässlich ist. Es wird erläutert, wie die ordnungsgemäße Verwendung eine optimale Skalierung von Inhalten und Benutzerinteraktion gewährleistet, während Missbrauch zu Design- und Zugänglichkeitsproblemen führen kann.

    Was ist der Zweck des & lt; iframe & gt; Etikett? Was sind die Sicherheitsüberlegungen bei der Verwendung? Was ist der Zweck des & lt; iframe & gt; Etikett? Was sind die Sicherheitsüberlegungen bei der Verwendung? Mar 20, 2025 pm 06:05 PM

    Der Artikel erörtert das & lt; iframe & gt; Der Zweck von Tag, externe Inhalte in Webseiten, seine gemeinsamen Verwendungen, Sicherheitsrisiken und Alternativen wie Objekt -Tags und APIs einzubetten.

    Gitee Pages statische Website -Bereitstellung fehlgeschlagen: Wie können Sie einzelne Dateien 404 Fehler beheben und beheben? Gitee Pages statische Website -Bereitstellung fehlgeschlagen: Wie können Sie einzelne Dateien 404 Fehler beheben und beheben? Apr 04, 2025 pm 11:54 PM

    GitePages statische Website -Bereitstellung fehlgeschlagen: 404 Fehlerbehebung und Auflösung bei der Verwendung von Gitee ...

    See all articles