当前位置: 首页 > backend >正文

Three.js + React 实战系列-3D 个人主页:构建 About 组件 (响应式 + 互动 + 动效)✨

对个人主页设计和实现感兴趣的朋友可以订阅我的专栏哦!!谢谢大家!!!

在本节中,我们将完成 3D 主页中的 About 介绍区域,它是用户了解你背景、技能、联系方式的第一入口。


这一组件不仅实现了 视觉信息分区、响应式布局适配、复制邮箱、动态 3D 地球 等关键功能,还通过图片与文字结合增强了展示效果。


✅前置条件:

  • npm install react-globe.gl

React + ThreeJS 个人主页小项目:🎥 04 · 构建 About 组件 (响应式 + 互动 + 动效)✨

🌟 组件亮点


功能描述
🖼️ 响应式网格布局兼容移动端与桌面,适应不同屏幕
🌍 动态地球 Globe使用 react-globe.gl 渲染交互式 3D 地球
📋 复制邮箱互动支持点击复制邮箱,反馈状态变更
🧠 信息模块划分技术栏目、兴趣、工作地点、联系方式等内容可视化呈现

📁 项目结构建议

组件路径:

src/
├— components/
│   └— About.jsx
└— assets/├— grid1.png ~ grid4.png├— copy.svg / tick.svg

📊 布局结构说明

整个组件采用 Tailwind CSS + CSS Grid 实现响应式布局:

<section className='c-space my-20' id="about"><div className='grid xl:grid-cols-3 xl:grid-rows-6 md:grid-cols-2 grid-cols-1 gap-5'>{/* 5 个内容块,分别为个人简介、技能、地球、热情、联系方式 */}</div>
</section>

根据屏幕尺寸使用 xl:grid-cols-3xl:grid-rows-6 实现大屏三列布局,小屏自动折行。


🌍 动态地球展示(Globe)

使用 react-globe.gl 组件来展示 3D 地球,并添加标签点:

<Globeheight={326}width={326}backgroundColor="rgba(0, 0, 0, 0)"globeImageUrl="//unpkg.com/three-globe/example/img/earth-day.jpg"bumpImageUrl="//unpkg.com/three-globe/example/img/earth-topology.png"labelsData={[{ lat: 32, lng: 112, text: 'XiangYang, China', color: 'white', size: 30 }]}
/>

✨ 高度适配不同设备,标签文字可添加多个城市。

globeImageUrl bumpImageUrl 可以在我的仓库中复制


📋 邮箱复制功能实现

通过 navigator.clipboard.writeText() 实现点击邮箱自动复制,并通过状态控制图标切换:

const [hasCopied, setHasCopied] = useState(false)const handleCopy = () => {navigator.clipboard.writeText('adrian@jsmastery.pro');setHasCopied(true);setTimeout(() => setHasCopied(false), 2000);
};
<div className="copy-container" onClick={handleCopy}><img src={hasCopied ? 'assets/tick.svg' : 'assets/copy.svg'} alt="copy" /><p className="text-white">adrian@jsmastery.pro</p>
</div>

✅ 用户点击后图标变为 ✅,2 秒后自动恢复。


📱 响应式适配说明

各内容块使用 Tailwind 工具类控制高度:

<img src="..." className="w-full sm:h-[276px] h-fit object-contain" />

同时不同网格区域使用:

  • col-span-X 控制宽度
  • row-span-X 控制纬向高度

例如:

<div className="xl:col-span-2 xl:row-span-3">...</div>

确保每个模块在移动端和桌面端都能有良好视觉分布。


✅ 总结

本节我们完成了一个具有视觉吸引力与互动能力的 About 页面:

  • ✅ 使用 CSS Grid 实现响应式布局
  • ✅ 集成 3D 地球提升科技感
  • ✅ 组件化组织图文展示区域
  • ✅ 实现邮箱点击复制与反馈动画

🔠 下一篇预告:作品展示区 + 动画出场

我们将在下一节中:

  • 🌟 构建项目展示区域(Projects)
  • ✨ 使用 gsap 为内容添加滑入动效
  • ⛳️ 实现点击跳转动效

对个人主页设计和实现感兴趣的朋友可以订阅我的专栏哦!!谢谢大家!!!
我们下一节见!👋

http://www.xdnf.cn/news/3489.html

相关文章:

  • 【Shell 脚本编程】详细指南:第四章 - 循环结构(for、while、until) 深度解析
  • Java 基础--数组(Array):存储数据的“排排坐”
  • 青蛙Todo:高效管理日程,提升工作学习效率
  • L39.【LeetCode题解】面试题 01.07. 旋转矩阵(四种方法)
  • 鸿蒙开发:如何解决软键盘弹出后的间距
  • [免费]SpringBoot+Vue非物质文化网站系统【论文+源码+SQL脚本】
  • 2025五一杯数学建模竞赛B题 矿山数据处理 保姆级教程讲解|模型讲解
  • Spring AI开发跃迁指南(第二章:急速上手3——Advisor核心原理、源码讲解及使用实例)
  • 如何使用网站备份到u盘,网站数据备份到U盘的方法
  • Python 函数装饰器和闭包(装饰器基础知识)
  • 二叉搜索树中的搜索(递归解决)
  • 【Shell 脚本编程】详细指南:第一章 - 基础入门与最佳实践
  • 软件工程国考
  • C++负载均衡远程调用学习之消息路分发机制
  • python创建Directory和python package的区别
  • 【分享】数据恢复大师6.10[特殊字符]恢复手机误删的数据[特殊字符]
  • 运维工作中,Ansible常用模块有哪些?
  • 【云备份】服务端工具类实现
  • 解决 Oracle EXPDP 無法鎖定 NFS 相關錯誤: ORA-27086 flock: No locks available
  • ActiveMQ 性能优化与网络配置实战(一)
  • 2025MathorCup数学应用挑战赛B题
  • 机器视觉开发-打开摄像头
  • GAMES202-高质量实时渲染(Real-time Environment Mapping)
  • 【二】 数字图像的运算 (下)【数字图像处理】
  • Java学习手册:Spring 数据访问
  • 系统架构设计师:设计模式概述
  • Centos7.9 安装mysql5.7
  • 突破zero-RL 困境!LUFFY 如何借离线策略指引提升推理能力?
  • 日语学习-日语知识点小记-构建基础-JLPT-N4阶段(13): ておきます ています & てあります
  • C++11新特性_Lambda 表达式