Ich muss einen transparenten Pfeil erstellen, wie im folgenden Skript gezeigt.Erstellen Sie einen transparenten Pfeil
.container{
height:250px;
background-image:url('https://pixabay.com/static/uploads/photo/2016/01/11/22/05/background-1134468_960_720.jpg');
position:relative;
overflow:hidden;
}
.container:after{
content:'';
clear:both;
display:block;
}
.left,
.right{
width:50%;
float:left;
height:100%;
}
.right{
background-color:#555;
}
.arrow1{
width: 0;
height: 0;
border: 125px solid transparent;
border-right: 50px solid #555;
position: absolute;
right: 50%;
top: 50%;
}
.arrow2{
width: 0;
height: 0;
border: 125px solid transparent;
border-right: 50px solid #555;
position: absolute;
right: 50%;
top: -50%;
}
<div class="container">
<div class="left"></div>
<div class="arrow1"></div>
<div class="arrow2"></div>
<div class="right"></div>
</div>
Ich habe Art, was ich will, aber das Problem ist, dass ich die Höhe von <div class="container">
weiß nicht, was auf 250px
hier zu Testzwecken eingestellt ist. die Grenze der .arrow1
muss immer die halbe Höhe von .container
sein. Da ich hier aber keine Prozentwerte verwenden kann, weiß ich nicht, wie ich es verstehen soll. Ich denke, der beste Weg wäre, eine Svg mit der Form zu haben, aber ich habe keine Vektorprogramme und die Online-Lösungen, die ich gefunden habe, werden nicht richtig funktionieren. Hat jemand einen alternativen Weg?
Sind Sie bereit, JS zu verwenden oder nicht? – Ephi
JS/JQuery ist kein Problem. Ich habe bereits versucht, '$ ('. Container'). Css ('height');' oder '$ ('. Container'). Height();' zu bekommen und die Hälfte der Höhe auf den Rand anzuwenden. Aber anscheinend bekomme ich nicht die richtige Höhe des Elements. Es ist immer zwischen 200 und 300 Pixel kleiner als es tatsächlich ist. –