【HTML + CSS 魔法秀】打造惊艳 3D 旋转卡片

HTML结构

  • box 类是整个组件的容器。
  • item-wrap 类是每个旋转卡片的包装器,每个都有一个内联样式--i,用于控制动画的延迟。
  • item类是实际的卡片内容,包含一个图片。
typescript 复制代码
<template>
  <div class="box">
    <div class="item-wrap" style="--i: 0">
      <div class="item"><img src="@/static/common_bot.png" alt="img" class="image" /></div>
    </div>
    <div class="item-wrap" style="--i: 1">
      <div class="item"><img src="@/static/common_bot.png" alt="img" class="image" /></div>
    </div>
    <div class="item-wrap" style="--i: 2">
      <div class="item"><img src="@/static/common_bot.png" alt="img" class="image" /></div>
    </div>
    <div class="item-wrap" style="--i: 3">
      <div class="item"><img src="@/static/common_bot.png" alt="img" class="image" /></div>
    </div>
    <div class="item-wrap" style="--i: 4">
      <div class="item"><img src="@/static/common_bot.png" alt="img" class="image" /></div>
    </div>
    <div class="item-wrap" style="--i: 5">
      <div class="item"><img src="@/static/common_bot.png" alt="img" class="image" /></div>
    </div>
  </div>
</template>

CSS样式

  • .item-wrap 使用display: contents;来移除包装器的边界框,只保留子元素的边界框。
  • animation 属性定义了一个名为slide的关键帧动画,每个.item-wrap根据--i变量的不同而有不同的延迟。
  • .item 类包含了一个transform属性,用于控制卡片的平移和缩放。
  • transition 属性定义了.item变换的过渡效果。
javascript 复制代码
<style scoped>
.box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: calc(100vh - 300px);
  background: rgba(31, 48, 53, 0.8);
}

.image {
  width: 100%;
  height: 100%;
}

@property --index {
  syntax: "<number>";
  initial-value: 0;
  inherits: false;
}

@keyframes slide {
  0% {
    --index: 0;
  }

  100% {
    --index: 6;
  }
}

.item-wrap {
  display: contents;
  animation: slide 12s calc(-2s * var(--i)) steps(6) infinite;
}

.item {
  position: absolute;
  display: grid;
  place-content: center;
  width: 180px;
  height: 180px;
  border-radius: 8px;
  background-color: rgba(67, 141, 255, 0.4);
  border: 1px solid rgba(67, 141, 255, 0.8);
  color: #fff;
  font-size: 30px;
  counter-increment: num;
  transform: translate(var(--translate)) scale(var(--scale));
  transition: .5s transform;
  animation: slide 12s calc(-2s * var(--i)) infinite;
}

.item-wrap:hover.item {
  animation-play-state: paused;
}

@container style(--index: 0) {
  .item {
    transform: translate(0, 0) scale(1);
    z-index: 4;
  }
}

@container style(--index: 1) {
  .item {
    transform: translate(120%, -30%) scale(0.9);
    z-index: 3;
  }
}

@container style(--index: 2) {
  .item {
    transform: translate(100%, -70%) scale(0.8);
    z-index: 2;
  }
}

@container style(--index: 3) {
  .item {
    transform: translate(0, -90%) scale(0.7);
    z-index: 1;
  }
}

@container style(--index: 4) {
  .item {
    transform: translate(-100%, -70%) scale(0.8);
    z-index: 2;
  }
}

@container style(--index: 5) {
  .item {
    transform: translate(-120%, -30%) scale(0.9);
    z-index: 3;
  }
}
</style>
相关推荐
唯之为之4 小时前
巧用mask属性创建一个纯CSS图标库
css·svg
寻找沙漠的人6 小时前
前端知识补充—CSS
前端·css
乔峰不是张无忌3309 小时前
【HTML】动态闪烁圣诞树+雪花+音效
前端·javascript·html·圣诞树
mirrornan9 小时前
3D和AR技术在电商行业的应用有哪些?
3d·ar·3d建模·3d模型·三维建模
NoneCoder9 小时前
CSS系列(29)-- Scroll Snap详解
前端·css
无言非影10 小时前
vtie项目中使用到了TailwindCSS,如何打包成一个单独的CSS文件(优化、压缩)
前端·css
羊小猪~~10 小时前
前端入门之VUE--ajax、vuex、router,最后的前端总结
前端·javascript·css·vue.js·vscode·ajax·html5
工业3D_大熊11 小时前
3D开发工具HOOPS助力造船业加速设计与数字化转型
3d
zaf赵11 小时前
3D 高斯溅射 (Gaussian Splatting)技术,一种实现超写实、高效渲染的突破性技术
3d
hanglove_lucky11 小时前
本地摄像头视频流在html中打开
前端·后端·html