当显示尺寸更改时,以不同方式对齐Flexbox

时间:2017-10-15 21:08:58

标签: html css css3 flexbox

我使用Flexboxes有以下HTML / CSS代码:

*{
 font-family:Arial;
}
html,
body {
  height: 100%;
  margin: 0
}
.flexbox {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  height: 100%;
  width: 100%
}
.flexbox .header{
  background: green;
  border:solid;
  font-size: 30;
  font-weight: bold;
  padding-left: 5;
}
.flexbox .main {
  flex: 1;
  background: red;
  position: relative
}

.flexbox-row {
  display: flex;
  position:absolute;
  height: 100%;
  width: 100%
}
.flexbox-row .links
{
  background: yellow;
  width:15%;
  height:100%;
}
.flexbox-row .second {
  flex: 1;
  background: blue;
  height:100%;
}


nav.sidenav {
    margin:0;
    background-color: white;
    overflow: auto;
    height:100%;
}


nav.sidenav a {
    display: block;
    color: black;
    text-decoration: none;
    padding: 8px;
    text-align: center;
}

nav.sidenav a.active {
    background-color: blue;
    color: white;
}

nav.sidenav a:hover {
    background-color: #555;
    color: white;
    text-decoration: underline;
}


@media screen and (max-width: 1000px) {
  nav.sidenav {
      width: 100%;
      height: auto;
      position: relative;
      border-top:none;
      border-bottom:solid;
      margin-top:0;
      }
      nav.sidenav a {
          float: left;
          padding: 8px;
      }
  .flexbox {
  display: flex;
  flex-direction: column;
  flex-wrap: initial;
  width: 100%
  }
  .flexbox-row .links{
  width:100%;
  }
  .flexbox-row .second {
  background: blue;
}

}
<div class="flexbox">

<div class="header">HeaderHeaderHeaderHeaderHeaderHeade</div>

<div class="main">
  <div class="flexbox-row">
    <div class="links">
      navbar
    </div>
    
    <div class="second"> content</div>
       
  </div>
</div>

如何在更改显示宽度时归档,Flexbox对齐如下: enter image description here

因此标题保持不变,然后是导航栏和内容。填写浏览器高度。 我刚接触css并且不太了解如何正确使用flexbox。

2 个答案:

答案 0 :(得分:1)

在媒体查询(@media screen and (max-width: 1000px) {...)中,添加

.flexbox-row {
  flex-direction: column;
}

.flexbox-row(即.links.second)的子元素放在彼此之下( - &gt; flex-direction: column;),这就是您在图片中所拥有的内容。以下是修改后的代码段:

*{
 font-family:Arial;
}
html,
body {
  height: 100%;
  margin: 0
}
.flexbox {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  height: 100%;
  width: 100%
}
.flexbox .header{
  background: green;
  border:solid;
  font-size: 30;
  font-weight: bold;
  padding-left: 5;
}
.flexbox .main {
  flex: 1;
  background: red;
  position: relative
}

.flexbox-row {
  display: flex;
  position:absolute;
  height: 100%;
  width: 100%
}
.flexbox-row .links
{
  background: yellow;
  width:15%;
  height:100%;
}
.flexbox-row .second {
  flex: 1;
  background: blue;
  height:100%;
}


nav.sidenav {
    margin:0;
    background-color: white;
    overflow: auto;
    height:100%;
}


nav.sidenav a {
    display: block;
    color: black;
    text-decoration: none;
    padding: 8px;
    text-align: center;
}

nav.sidenav a.active {
    background-color: blue;
    color: white;
}

nav.sidenav a:hover {
    background-color: #555;
    color: white;
    text-decoration: underline;
}


@media screen and (max-width: 1000px) {
  nav.sidenav {
      width: 100%;
      height: auto;
      position: relative;
      border-top:none;
      border-bottom:solid;
      margin-top:0;
      }
      nav.sidenav a {
          float: left;
          padding: 8px;
      }
  .flexbox {
  display: flex;
  flex-direction: column;
  flex-wrap: initial;
  width: 100%
  }
  .flexbox-row .links{
  width:100%;
  }
  .flexbox-row .second {
  background: blue;
}
.flexbox-row {
  flex-direction: column;
}
}
<div class="flexbox">

<div class="header">HeaderHeaderHeaderHeaderHeaderHeade</div>

<div class="main">
  <div class="flexbox-row">
    <div class="links">
      navbar
    </div>
    
    <div class="second"> content</div>
       
  </div>
</div>

答案 1 :(得分:1)

两件主要的事情:

  • 在较窄的屏幕上,使用媒体查询,将content放在links
  • 下方
  • 取消绝对定位并改为使用Flexbox,因此内容大小适当

我在CSS中添加了很多笔记,解释了什么以及为什么。

* {
  font-family: Arial;
}

html,body {
  height: 100%;
  margin: 0
}

.flexbox {
  display: flex;
  flex-direction: column;
  /*flex-wrap: nowrap;           not needed, default value  */
  height: 100%;
  /*width: 100%                  not needed, default behavior  */
}

.flexbox .header {
  background: green;
  border: solid;
  font-size: 30;
  font-weight: bold;
  padding-left: 5px;         /*  need unit, added "px"  */
}

.flexbox .main {
  flex: 1;
  background: red;
  /*position: relative;          not needed anymore  */
  display: flex;             /*  instead of absolute position  */ 
}

.flexbox-row {
  display: flex;
  /*position: absolute;          not needed anymore  */
  /*height: 100%;                not needed when parent has display: flex  */
  width: 100%;
}

.flexbox-row .links {
  background: yellow;
  width: 15%;
  /*height: 100%;                not needed when parent has display: flex  */
}

.flexbox-row .second {
  flex: 1;
  background: blue;
  /*height: 100%;                not needed when parent has display: flex  */
}


nav.sidenav {
  margin: 0;
  background-color: white;
  overflow: auto;
  height: 100%;
}

nav.sidenav a {
  display: block;
  color: black;
  text-decoration: none;
  padding: 8px;
  text-align: center;
}

nav.sidenav a.active {
  background-color: blue;
  color: white;
}

nav.sidenav a:hover {
  background-color: #555;
  color: white;
  text-decoration: underline;
}

@media screen and (max-width: 1000px) {
  nav.sidenav {
    width: 100%;
    height: auto;
    position: relative;
    border-top: none;
    border-bottom: solid;
    margin-top: 0;
  }
  nav.sidenav a {
    float: left;
    padding: 8px;
  }
  /*  not needed, already set
  .flexbox {
    display: flex;
    flex-direction: column;
    flex-wrap: initial;
    width: 100%;
  }
  */
  .flexbox-row {
    flex-direction: column;  /*  added, put content below navbar  */
  }
  .flexbox-row .links {
    width: 100%;
  }
  /*  not needed, already set
  .flexbox-row .second {
    background: blue;
  }
  */
}
<div class="flexbox">

  <div class="header">HeaderHeaderHeaderHeaderHeaderHeader</div>

  <div class="main">  
    <div class="flexbox-row">
      <div class="links">
        navbar
      </div>
      <div class="second">
        content
      </div>
    </div>
  </div>
  
</div>