3D倾斜图片列表布局特效
css代码
.images-leaning {
box-sizing: border-box;
width: 100%;
min-width: 800px;
margin: 10em auto 0;
min-height: 330px;
position: relative;
background-repeat: no-repeat;
background-image: linear-gradient(352deg, transparent 45.2%, #bbb 45.5%, #bbb 45.6%, #ccc 45.8%, #eee 60%), linear-gradient(30deg, #ccc, #eee 90%);
background-size: 100% 32.4em;
background-position: 50% 100%;
}
.images-leaning > div {
width: 250px;
position: absolute;
left: 50%;
bottom: 7.8em;
z-index: 0;
display: -webkit-box;
display: flex;
-webkit-box-pack: end;
justify-content: flex-end;
}
.images-leaning > div:before {
content: '';
width: 60%;
height: 100%;
position: absolute;
left: 0;
top: 7%;
z-index: 1;
background-repeat: no-repeat;
background-image: linear-gradient(120deg, transparent 42%, rgba(0,0,0,0.15) 45%, rgba(0,0,0,0.35) 65%), linear-gradient(20deg, transparent 38%, rgba(0,0,0,0.25) 45%, rgba(0,0,0,0.23) 55%, rgba(0,0,0,0.13) 75%), radial-gradient(ellipse at 50% 100%, rgba(0,0,0,0.15) 3%, transparent 40%);
-webkit-transform: rotate(-8deg);
transform: rotate(-8deg);
}
.images-leaning > div:after {
content: '';
width: 60%;
height: 100%;
position: absolute;
z-index: 3;
background-image: linear-gradient(45deg, rgba(0,0,0,0.3), transparent 70%), linear-gradient(45deg, rgba(255,255,255,0) 60%, rgba(255,255,255,0.3) 80%);
-webkit-transform: perspective(20em) rotateY(1deg) rotateZ(-5deg) skewY(-2deg) skewX(-1deg) scaleX(var(--resize));
transform: perspective(20em) rotateY(1deg) rotateZ(-5deg) skewY(-2deg) skewX(-1deg) scaleX(var(--resize));
}
.images-leaning > div > img {
width: 60%;
height: 100%;
display: block;
position: relative;
z-index: 2;
border-left: 0.2em solid;
-webkit-border-image: linear-gradient(105deg, transparent 0.5%, #aaa 0.7%) 1;
-o-border-image: linear-gradient(105deg, transparent 0.5%, #aaa 0.7%) 1;
border-image: linear-gradient(105deg, transparent 0.5%, #aaa 0.7%) 1;
box-shadow: 0.1em 0.2em 0 -0.1em #666;
-webkit-filter: saturate(90%);
filter: saturate(90%);
-webkit-transform: perspective(20em) rotateY(1deg) rotateZ(-5deg) skewY(-2deg) skewX(-1deg) scaleX(var(--resize));
transform: perspective(20em) rotateY(1deg) rotateZ(-5deg) skewY(-2deg) skewX(-1deg) scaleX(var(--resize));
}
.images-leaning > div:nth-of-type(4) {
--resize: 0.99;
margin-left: -40.4em;
}
.images-leaning > div:nth-of-type(4):before {
background-size: 100% 85%, 100% 15%, 100% 10%;
background-position: 0.1em 0, 0 100%, -3em 83%;
}
.images-leaning > div:nth-of-type(3) {
--resize: 0.96;
margin-left: -15.3em;
-webkit-transform: scaleY(0.98) translate(-8em, -2.1em);
transform: scaleY(0.98) translate(-8em, -2.1em);
}
.images-leaning > div:nth-of-type(3):before {
background-size: 100% 84%, 100% 16%, 100% 10%;
background-position: 0.4em 0, 0 100%, -3em 81%;
}
.images-leaning > div:nth-of-type(2) {
--resize: 0.925;
margin-left: 10em;
-webkit-transform: scaleY(0.965) translate(-17em, -4.2em);
transform: scaleY(0.965) translate(-17em, -4.2em);
}
.images-leaning > div:nth-of-type(2):before {
background-size: 100% 83%, 100% 17%, 100% 10%;
background-position: 0.6em 0, 0.1em 100%, -3em 81%;
}
.images-leaning > div:nth-of-type(1) {
--resize: 0.895;
margin-left: 35.2em;
-webkit-transform: scaleY(0.94) translate(-26.6em, -6.2em);
transform: scaleY(0.94) translate(-26.6em, -6.2em);
}
.images-leaning > div:nth-of-type(1):before {
background-size: 100% 82%, 100% 18%, 100% 10%;
background-position: 0.8em 0, 0.1em 100%, -3em 80%;
}
html,
body {
min-height: 100vh;
min-width: 800px;
}
body {
margin: 0 auto;
padding: 0;
display: -webkit-box;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
flex-direction: column;
-webkit-box-pack: justify;
justify-content: space-between;
background-color: #eee;
font-size: 10px;
}
.images-basic {
width: 600px;
padding: 5em 0;
margin: 0 auto;
display: -webkit-box;
display: flex;
-webkit-box-pack: justify;
justify-content: space-between;
-webkit-box-orient: horizontal;
-webkit-box-direction: reverse;
flex-direction: row-reverse;
}
.images-basic > div {
width: 130px;
}
.images-basic img {
width: 100%;
display: block;
}
html代码
<div class="images-basic">
<div>
<img src="./eleanor.jpg" alt="Eleanor from The Good Place">
</div>
<div>
<img src="./chidi.jpg" alt="Chidi from The Good Place">
</div>
<div>
<img src="./jason.jpg" alt="Jason from The Good Place">
</div>
<div>
<img src="./tahani.jpg" alt="Tahani from The Good Place">
</div>
</div>
<div class="images-leaning">
<div>
<img src="./eleanor.jpg" alt="Eleanor from The Good Place">
</div>
<div>
<img src="./chidi.jpg" alt="Chidi from The Good Place">
</div>
<div>
<img src="./jason.jpg" alt="Jason from The Good Place">
</div>
<div>
<img src="./tahani.jpg" alt="Tahani from The Good Place">
</div>
</div>