用户社交信息交互卡片

效果展示

CSS 知识点

  • CSS 基础知识回顾
  • transition-delay 属性的运用

整体页面布局实现

html 复制代码
<div class="card">
  <div class="user">
    <div class="img_box">
      <img src="bg.jpg" />
    </div>
    <div class="content">
      <h2>
        Someone Famous
        <br />
        <span>Product Designer</span>
      </h2>
    </div>
    <span class="toggle"></span>
  </div>
  <ul class="contact">
    <li style="--clr: #c71610;--i:0">
      <a href="#">
        <div class="icon_box">
          <i class="fa-solid fa-envelope"></i>
        </div>
        <p>someone@email.com</p>
      </a>
    </li>
    <li style="--clr: #171515;--i:1">
      <a href="#">
        <div class="icon_box">
          <i class="fa-brands fa-weixin"></i>
        </div>
        <p>18372876781</p>
      </a>
    </li>
    <li style="--clr: #0a66c2;--i:2">
      <a href="#">
        <div class="icon_box">
          <i class="fa-brands fa-qq"></i>
        </div>
        <p>38572913</p>
      </a>
    </li>
  </ul>
</div>

实现整体用户卡片样式

css 复制代码
.card {
  position: relative;
  height: 100px;
  transition: 0.5s;
  transition-delay: 0.5s;
}

.card .user {
  position: relative;
  width: 400px;
  min-height: 150px;
  background: #2196f3;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 10px;
  border-radius: 10px;
  padding: 60px 40px 30px;
}

实现用户头像样式

css 复制代码
.card .user .img_box {
  position: absolute;
  top: 0;
  transform: translateY(-50%);
  width: 100px;
  height: 100px;
  border-radius: 50%;
  border: 6px solid #fff;
  overflow: hidden;
  transition: 0.5s;
  z-index: 10;
}

.card .user .img_box img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

实现用户信息部分样式

css 复制代码
.card .user .content {
  position: relative;
  text-align: center;
}

.card .user .content h2 {
  font-size: 1.2em;
  line-height: 1.05;
  color: #fff;
}

.card .user .content h2 span {
  font-size: 0.75em;
  font-weight: 400;
}

实现用户社交信息展示的按钮样式

css 复制代码
.card .user .toggle {
  position: absolute;
  bottom: 0;
  width: 120px;
  padding: 5px 15px;
  background: #fff;
  border-radius: 30px;
  transform: translateY(50%);
  border: 6px solid var(--bg);
  text-align: center;
  cursor: pointer;
  font-weight: 500;
  transition: 0.5s;
}

.card .user .toggle::before {
  content: "Hire me";
}

使用 JavaScript 实现按钮交互事件

javascript 复制代码
let toggle = document.querySelector(".toggle");
let card = document.querySelector(".card");

toggle.onclick = () => {
  card.classList.toggle("active");
};

编写社交项的样式

css 复制代码
.card .contact {
  position: relative;
  top: 30px;
  width: 100%;
  height: 0;
  display: flex;
  overflow: hidden;
  flex-direction: column;
  gap: 10px;
  transition: 0.5s;
}

.card .contact li {
  list-style: none;
  width: 100%;
  min-height: 100px;
  background: #fff;
  border-radius: 10px;
  display: flex;
  transition: 0.5s;
  opacity: 0;
  transform: scale(0);
  padding: 10px 30px;
}

/* 剩余样式在完整代码中展示 */

编写卡片激活后的样式

css 复制代码
/* 只是展示部分样式 */

.card.active {
  height: 450px;
  transition-delay: 0;
}

.card.active .user .toggle {
  background: #ff4383;
  color: #fff;
}

.card.active .contact {
  height: 325px;
}

.card.active .contact li {
  opacity: 1;
  transform: scale(1);
  transition-delay: calc(0.25s * var(--i));
}

.card.active .contact:hover li {
  opacity: 0.15;
  filter: blur(2px);
  transition-delay: 0s;
}

.card.active .contact li:hover {
  opacity: 1;
  filter: blur(0px);
}

完整代码下载

完整代码下载

相关推荐
一尾流莺几秒前
狼人杀娱乐版型介绍
前端
wuhen_n几秒前
v-once和v-memo完全指南:告别不必要的渲染,让应用飞起来
前端·javascript·vue.js
干前端7 分钟前
Vue3 组件库实战(六):从本地到 NPM,Vue 组件库工程化构建与打包全指南(上)
前端·vue.js·npm
fjhcom8 分钟前
PDF与图片互转WEB应用开发教程
前端·pdf·图片·web应用·streamlit
云原生指北9 分钟前
记忆不上云:mem9 + TiDB 打造 OpenClaw 私有记忆中枢
前端
IT_陈寒10 分钟前
Vite vs Webpack终极对决:5个关键指标告诉你谁更快?
前端·人工智能·后端
Moment12 分钟前
2026 年前端 Agent 框架选型:Mastra 与 LangChain 该怎么选
前端·后端·面试
云浪15 分钟前
5 分钟入门 fetch
前端·javascript
晓得迷路了21 分钟前
栗子前端技术周刊第 120 期 - Vite 8.0、Solid v2.0.0 Beta、TypeScript 6.0 RC...
前端·javascript·vite
学习3人组22 分钟前
PowerShell 执行策略限制导致的 `npm` 命令无法运行的安全错误
前端·安全·npm