gpt4 book ai didi

html - 如何使用 CSS 制作折叠丝带效果?

转载 作者:行者123 更新时间:2023-12-03 18:33:57 25 4
gpt4 key购买 nike

我正在尝试将基于图像的信息图形转换为 html 和 css。我可以在那里获得 90%,但我正在寻找有关折叠丝带效果的帮助。
信息图有是/否方向,如下所示:

“丝带”的末端折叠在下面,并用较深的原色阴影戳出底部。

CSS ribbon shape

这是我到目前为止所拥有的:

<style>
.container { display: flex; flex-wrap: wrap; background-color: white; border-radius: 1em; }
.container .header { width: 100%; font-size: 3em; font-weight: bold; line-height: 0.9; padding: 1em 3em !important; text-align: center }
.container .child:first-child { width: 100%; }
.container .child:not(:first-child) { width: 50%; font-size: 13px; }
.container .child { display: inline-block; padding: 1em; }
.container .leftcol { border-right: 2px solid black; }
.container .redright { position: relative; background-color: #cd1719; color: white; font-size: 3em; font-weight: bold; padding-left: 0.5em; border-radius: 0.25em; margin-bottom: 0.5em; }
.container .greenleft { position: relative; background-color: #7fbc03; color: white; text-align: right; font-size: 3em; font-weight: bold; padding-right: 0.5em; border-radius: 0.25em; margin-bottom: 0.5em; }
.container .greenleft::before { content: ""; position: absolute; top: 0; left: 0; border-width: 1.5em 1em 1.25em 0; border-color: white #7fbc03 transparent transparent; display: block; border-style: solid; bottom: -1em; }
</style>
    <div class="container">
<div class="child header">Header</div>
<div class="child leftcol">
<div class="greenleft">Yes</div>
<p>Content on the left</p>
</div>
<div class="child rightcol">
<div class="redright">No</div>
<p>Content on the right</p>
</div>
</div>

最佳答案

我会这样做:

.box {
width: 200px;
padding: 10px 20px;
margin: 40px 80px;
color: #fff;
text-align: right;
background: #7fbc03;
border-radius: 8px;
position: relative;
z-index: 0;
}

.box::before,
.box::after {
content: "";
position: absolute;
z-index: -1;
top: 0;
bottom: 0;
background: inherit;
border-radius:inherit;
border-bottom-left-radius:0;
transform-origin: top left;
}

.box::before {
left: 0;
right: 20%;
transform: skewX(-40deg);
}

.box::after {
z-index: -2;
left: 1px;
height: 130%; /* ~ 100%/cos(40deg) */
width: 40px;
filter: brightness(0.7);
transform: rotate(40deg);
}

.right {
text-align: left;
background: #cd1719;
}

.right::before {
right: 0;
left: 20%;
border-bottom-right-radius:0;
border-bottom-left-radius:inherit;
transform: skewX(40deg);
}

.right::after {
right: 1px;
left: auto;
transform-origin: top right;
border-bottom-right-radius:0;
border-bottom-left-radius:inherit;
transform: rotate(-40deg);
}
<div class="box">YES</div>

<div class="box right">NO</div>

<div class="box right" style="background:lightblue;">Two <br> lines</div>

<div class="box" style="background:purple;width:auto;">full width</div>

<div class="box right" style="background:orange;width:auto;display:inline-block">auto width</div>


CSS folded ribbon

关于html - 如何使用 CSS 制作折叠丝带效果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62076359/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com