html - Flexbox:居中正文内容

标签 html css flexbox

我有这个布局 here .我试图让 body 内的一切都居中。除了我在链接和下面的代码中尝试过的内容之外,我还尝试过向包装器添加一个 flex-display 属性,但这也没有成功。我不完全确定我做错了什么,因为我相信 justify-content: center;应该可以解决问题,对吧?

还有一件事:我的 <main> 上方和下方有一条丑陋的背景色 strip .如何在不删除 <main> 的情况下解决此问题标签(这是我发现到目前为止唯一有效的想法)?我应该使用包装器 div 而不是主标记吗?

html {
  height: 100%;
  background: #f5f5f5;
}
body {
  height: 100%;
  width: 70%;
  display: flex;
  display: -webkit-flex;
  flex-direction: column;
  -webkit-flex-direction: column;
  font-family: "sans-serif";
  align-items: center;
  -webkit-align-items: center;
}
.wrapper {
  -webkit-box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
  max-width: 980px;
}
header {
  display: flex;
  display: -webkit-flex;
  flex-direction: row;
  -webkit-flex-direction: row;
  justify-content: flex-end;
  -webkit-justify-content: flex-end;
  align-items: center;
  -webkit-align-items: center;
  background: #42A8C0;
  width: 100%;
  color: white;
}
.name-container {
  flex: 1 0 auto;
  -webkit-flex: 1 0 auto;
  text-align: center;
}
.name-container h1 {
  font-weight: 100;
  letter-spacing: 2px;
  font-size: 40px;
}
.name-container h4 {
  font-weight: 500;
  letter-spacing: 1px;
}
.profile-container {
  flex: 0 0 auto;
  -webkit-flex: 0 0 auto;
  background: rgba(0, 0, 0, 0.2);
  display: flex;
  display: -webkit-flex;
  padding: 10px;
}
.social-container {
  display: flex;
  display: -webkit-flex;
  flex-direction: column;
  -webkit-flex-direction: column;
  font-size: 20px;
  margin-top: 10px;
}
.social-container a {
  color: white;
  text-decoration: none;
}
.social-container a:hover {
  text-decoration: underline;
}
.contact-list {
  list-style-type: none;
}
.contact-list .fa {
  margin-right: 10px;
  font-size: 20px;
  vertical-align: middle;
}
.contact-list li {
  margin-bottom: 5px;
}
.portrait-pic {
  border-radius: 50%;
  height: 200px;
  width: 200px;
}
main {
  background: white;
  flex: 1 0 auto;
  -webkit-flex: 1 0 auto;
  width: 100%;
  color: black;
}
section {
  padding-left: 20px;
  padding-right: 20px
}
.summ-box {
  margin: 20px auto;
  text-align: center;
}
p {
  font-weight: 200;
  letter-spacing: 1px;
}
<div class="wrapper">
  <header>
    <div class="name-container">
      <h1>My Name</h1>
      <h4>Small summary of current position</h4>
    </div>
    <!--/name-container-->
    <div class="profile-container">
      <div class="social-container">
        <ul class="contact-list">
          <li class="email"><a href="mailto: yourname@email.com"><i class="fa fa-envelope" aria-hidden="true"></i></a><a href="mailto: yourname@email.com">yourname@email.com</a>
          </li>
          <li class="website"><a href="http://www.google.com" target="_blank"><i class="fa fa-globe" aria-hidden="true"></i></a><a href="http://www.google.com" target="_blank">portfoliosite.com</a>
          </li>
          <li class="linkedin"><a href="http://www.google.com" target="_blank"><i class="fa fa-linkedin" aria-hidden="true"></i></a><a href="http://www.google.com" target="_blank">linkedin.com/inname</a>
          </li>
          <li class="github"><a href="http://www.google.com" target="_blank"><i class="fa fa-github" aria-hidden="true"></i></a><a href="http://www.google.com" target="_blank">github.com/username</a>
          </li>
          <li class="twitter"><a href="http://www.google.com" target="_blank"><i class="fa fa-twitter" aria-hidden="true"></i></a><a href="http://www.google.com" target="_blank">@twittername</a>
          </li>
        </ul>
      </div>
      <!--/social-container-->
      <div class="picture-container">
        <img src="https://cdn.pixabay.com/photo/2016/02/22/18/57/puppy-1216269_960_720.jpg" class="portrait-pic">
      </div>
      <!--/picture-container-->
    </div>
    <!--/profile-container-->
  </header>
  <!--/header-->
  <main>
    <section class="summ-box">
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Tria genera bonorum; Nec vero alia sunt quaerenda contra Carneadeam illam sententiam. Quae quidem vel cum periculo est quaerenda vobis; Beatum, inquit. Duo Reges: constructio interrete.</p>
      <div class="line-break"></div>
      <!--/line-break-->
    </section>
    <!--/summ-box-->
  </main>
  <!--/main-->
</div>
<!--/wrapper-->

最佳答案

body 元素中移除 width: 70%。它不会为居中留下任何额外的空间。

关于html - Flexbox:居中正文内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42140491/

相关文章:

html - 如何将 HTML 页面垂直分成 4 个部分

windows - Firefox 4 Windows 仅 "bug"和 :after/:before CSS selectors?

html - 如何防止文本区域重叠

html - 使用 flexbox 对齐元素中心的拉伸(stretch)高度

html - CSS Transform 转换到窗口中心

html - 如何使用 XSLT 选择第一个元素?

javascript - 禁用按 Tab 按钮进入 Web 表单中的下一个输入字段

html - flexbox 后的元素定位不正确

html - 如何让 flexbox 盒子可选?

react-native - 如何使用 Flex 每行放置 2 张卡片