3D倾斜图片列表布局特效

2020-11-09 11:28发布

在这里插入图片描述
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;}123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137

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>


作者:诗水人间
链接:https://blog.csdn.net/qq_41813208/article/details/107461642
来源:CSDN
著作权归作者所有,转载请联系作者获得授权,切勿私自转载。