修复倾斜的Flexbox

问题描述 投票:-2回答:2

我需要做一个倾斜的CSS设计的网站。目标是一些类似的设计:enter image description here

一些编码后的结果如下:enter image description here

在黑匣子中你可以看到问题:ABC容器不在正确的位置。我怎么能解决这个问题?

html, body {
  margin: 0px;
  padding: 0px;
  width: 100%;
  font-family: sans-serif;
  font-size: 20px;
}

a {
  text-transform: uppercase;
  font-family: sans-serif;
  font-size: 30px;
  text-decoration: none;
  margin-left: auto;
  margin-right: auto;
  font-weight: bold;
  color: white;
}

.flex-container {
  display: flex;
  align-self: left;
  flex-direction: row;
  width: 70%;
  height: 100%;
  background-color: white;
  overflow: hidden;
  flex-wrap: wrap-reverse;
  float: right;
}

.flex-content {
  transform: skew(-5.5deg);
  background-color: red;
  height: 33%;
  text-align: center;
  width: 45%;
  margin: 5px 5px 5px 50px;
  display: flex;
  align-items: center;
}

.underlay-box {
  position: absolute;
  width: 20%;
  height: 100%;
  background-color: red;
}

.overlay-box {
  width: 30%;
  height: 100%;
  background-color: red;
  transform: skew(-5.5deg);
  float: left;
}

.gmk {
  height: 100%;
  width: 100%;
  border: 2px red solid;
  /*background: url('bild1.jpg'); */
  background-size: cover;
}
<div class="underlay-box"></div>
<div class="overlay-box"></div>
<div class="flex-container">
  <div class="flex-content">
    <div class="gmk"><a href="mediothek.html">A</a></div>
  </div>
  <div class="flex-content"><a href="mediothek.html">B</a></div>
  <div class="flex-content"><a href="mediothek.html">C</a></div>
  <div class="flex-content"><a href="mediothek.html">D</a></div>
  <div class="flex-content"><a href="mediothek.html">E</a></div>
  <div class="flex-content"><a href="mediothek.html">F</a></div>
</div>

我将不胜感激任何帮助:)谢谢你,乔纳斯

html css flexbox skew
2个回答
2
投票

做出的改变:

  • 歪斜弹性容器而不是倾斜每个元素。
  • 使用skewX()而不仅仅是skew()。
  • 通过减小边框大小和每个弹性项目的divison宽度来计算组件的弹性基础。
  • 只需使用左侧面板的底座盒,将其倾斜并将其平移至左侧的-5%即可。
  • 增加弹性容器的宽度,使其向右溢出身体。
  • 隐藏,body标签的overflow-x以禁用滚动。

html,
body {
  margin: 0px;
  padding: 0px;
  width: 100%;
  font-family: sans-serif;
  font-size: 20px;
  overflow-x:hidden;
}

a {
  text-transform: uppercase;
  font-family: sans-serif;
  font-size: 30px;
  text-decoration: none;
  margin-left: auto;
  margin-right: auto;
  font-weight: bold;
  color: white;
}

.flex-container {
  display: flex;
  align-self: left;
  flex-direction: row;
  width: 80%;
  height: 100%;
  transform: skewX(-5.5deg);
  background-color: white;
  overflow: hidden;
  flex-wrap: wrap-reverse;
  position: absolute;
  left: 25%;
  
}

.flex-content {
  background-color: red;
  border:2px solid black;
  flex: 0 1 calc(32% - 2px);
  display: flex;
  align-items: center;
  text-align: center;
}

.flex-content:hover{
background-color:gray;
transition:all 0.3s ease-in-out;
}

.underlay-box {
  position: absolute;
  left: -5%;
  width: 30%;
  height: 100%;
  background-color: red;
  transform: skewX(-5.5deg);
}

.gmk {
  height: 100%;
  width: 100%;
  border: 2px red solid;
  /*background: url('bild1.jpg'); */
  background-size: cover;
}
<div class="underlay-box"></div>
<div class="overlay-box"></div>
<div class="flex-container">
  <div class="flex-content">
    <div class="gmk"><a href="mediothek.html">A</a></div>
  </div>
  <div class="flex-content"><a href="mediothek.html">B</a></div>
  <div class="flex-content"><a href="mediothek.html">C</a></div>
  <div class="flex-content"><a href="mediothek.html">D</a></div>
  <div class="flex-content"><a href="mediothek.html">E</a></div>
  <div class="flex-content"><a href="mediothek.html">C</a></div>
  <div class="flex-content"><a href="mediothek.html">D</a></div>
  <div class="flex-content"><a href="mediothek.html">E</a></div>
  <div class="flex-content"><a href="mediothek.html">F</a></div>
</div>

2
投票

我认为更好的方法是将skew应用于.flex-container

基本问题是你自己扭曲每个元素,因此它就地偏斜了。倾斜容器将允许其内容物在倾斜外部形状的同时倾斜。

html, body {
  margin: 0px;
  padding: 0px;
  width: 100%;
  height:100%;
  font-family: sans-serif;
  font-size: 20px;
}
a {
  text-transform: uppercase;
  font-family: sans-serif;
  font-size: 30px;
  text-decoration: none;
  margin-left: auto;
  margin-right: auto;
  font-weight: bold;
  color: white;
}

.flex-container {
  display: flex;
  align-self: left;
  flex-direction: row;
  width: 70%;
  height: 100%;
  background-color: white;
  overflow: hidden;
  flex-wrap: wrap-reverse;
  float: right;
  transform: skew(-5.5deg);
}

.flex-content {
  background-color: red;
  height: 33%;
  text-align: center;
  width: 45%;
  margin: 5px 5px 5px 15px;
  display: flex;
  align-items: center;
}

.underlay-box {
  position: absolute;
  width: 20%;
  height: 100%;
  background-color: red;
}

.overlay-box {
  width: 30%;
  height: 100%;
  background-color: red;
  transform: skew(-5.5deg);
  float: left;
}

.gmk {
  height: 100%;
  width: 100%;
  border: 2px red solid;
  /*background: url('bild1.jpg'); */
  background-size: cover;
  box-sizing:border-box;
}
<div class="underlay-box"></div>
<div class="overlay-box"></div>
<div class="flex-container">
  <div class="flex-content">
    <div class="gmk"><a href="mediothek.html">A</a></div>
  </div>
  <div class="flex-content"><a href="mediothek.html">B</a></div>
  <div class="flex-content"><a href="mediothek.html">C</a></div>
  <div class="flex-content"><a href="mediothek.html">D</a></div>
  <div class="flex-content"><a href="mediothek.html">E</a></div>
  <div class="flex-content"><a href="mediothek.html">F</a></div>
</div>
© www.soinside.com 2019 - 2024. All rights reserved.