多卡片效果悬停效果

效果展示

页面结构

从页面的结构上看,在默认状态下毛玻璃卡片是有层次感的效果叠加在一起,并且鼠标悬停在卡片区域后,卡片整齐排列。

CSS3 知识点

  • transform 属性的 rotate 值运用
  • content 属性的 attr 值运用

实现页面整体布局

html 复制代码
<div class="container">
  <div class="glass" style="--i: -15" data-text="Design">
    <i class="fa-solid fa-pen"></i>
  </div>
  <div class="glass" style="--i: 5" data-text="Code">
    <i class="fa-solid fa-code"></i>
  </div>
  <div class="glass" style="--i: 25" data-text="Launch">
    <i class="fa-solid fa-rocket"></i>
  </div>
  <div class="glass" style="--i: -15" data-text="Earn">
    <i class="fa-solid fa-money-check-dollar"></i>
  </div>
</div>

实现卡片的样式

css 复制代码
.container .glass {
  position: relative;
  width: 200px;
  height: 240px;
  background: linear-gradient(#fff2, transparent);
  border: 1px solid rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(10px);
  display: flex;
  justify-content: center;
  align-items: center;
  transition: 0.5s;
  border-radius: 10px;
  margin: 0 -45px;
  /* 获取HTML中的样式变量值 */
  transform: rotate(calc(var(--i) * 1deg));
}

.container:hover .glass {
  transform: rotate(0deg);
  margin: 0 20px;
}

实现卡片悬停样式

css 复制代码
.container .glass::before {
  /* 获取HTML页面中的文字变量值 */
  content: attr(data-text);
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 40px;
  background: rgba(255, 255, 255, 0.05);
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
}

.container .glass i {
  font-size: 5em;
  color: #fff;
}

完整代码下载

完整代码下载

相关推荐
华仔啊24 分钟前
图片标签用 img 还是 picture?很多人彻底弄混了!
前端·html
lichong95130 分钟前
XLog debug 开启打印日志,release 关闭打印日志
android·java·前端
烟袅1 小时前
作用域链 × 闭包:三段代码,看懂 JavaScript 的套娃人生
前端·javascript
风止何安啊1 小时前
收到字节的短信:Trae SOLO上线了?尝尝鲜,浅浅做个音乐播放器
前端·html·trae
抱琴_1 小时前
大屏性能优化终极方案:请求合并+智能缓存双剑合璧
前端·javascript
用户463989754321 小时前
Harmony os——长时任务(Continuous Task,ArkTS)
前端
fruge1 小时前
低版本浏览器兼容方案:IE11 适配 ES6 语法与 CSS 新特性
前端·css·es6
颜酱2 小时前
开发工具链-构建、测试、代码质量校验常用包的比较
前端·javascript·node.js
颜酱2 小时前
package.json 配置指南
前端·javascript·node.js
todoitbo2 小时前
基于 DevUI MateChat 搭建前端编程学习智能助手:从痛点到解决方案
前端·学习·ai·状态模式·devui·matechat