用户名
Email
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
帖子
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
IT评测·应用市场-qidao123.com技术社区
»
论坛
›
软件与程序人生
›
前端开发
›
前端练习<Html&CSS>——照片墙(附完整代码及实现结果 ...
前端练习<Html&CSS>——照片墙(附完整代码及实现结果) ...
李优秀
论坛元老
|
2024-8-18 22:42:07
|
显示全部楼层
|
阅读模式
楼主
主题
1377
|
帖子
1377
|
积分
4131
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
这个小练习也泉源于b站up小K师兄,大家可以通过下面的链接学习哦~up讲的非常详细。
纯CSS写一个简单酷炫的照片墙结果~
先看一下这个照片墙的结果:
1.鼠标没有放到图片上时,照片同比例,每张照片都有倒影的结果。
2.然后是鼠标放置图片上的结果,图片被放大,其他照片旋转缩放,这里必要注意,左右双方的照片是对称倾斜的。
HTML结构
<style>标签内包含了CSS样式,用于定义页面的样式。
<body>标签内包含了一个<div>元素,类名为container,这个容器包含了多个<div>元素,每个<div>元素类名为box,每个box元素内包含一个<img>元素,用于展示图片。
CSS样式
*选择器用于重置所有元素的默认样式,包括margin和padding,并设置box-sizing为border-box,这样元素的宽度和高度就包括了边框和内边距。
body选择器设置了display为flex,并使用justify-content和align-items属性将内容水平和垂直居中,同时设置了最小高度为100vh,背景颜色为#1a252c。
.container选择器设置了容器的样式,包括position、display、justify-content、align-items和transform-origin属性,用于实现3D翻转结果。
.container .box选择器设置了每个图片容器的样式,包括宽度、高度、位置、过渡结果和反射结果。
.container .box img选择器设置了图片的样式,包括绝对定位、宽度和高度。
.container:hover> :not(:hover)选择器用于在鼠标悬停在容器上时,除了悬停的图片容器之外的其他图片容器会向两侧移动,并添加阴影结果和3D旋转。
.container .box:hover~.box选择器用于在鼠标悬停在某个图片容器上时,其他图片容器会进行3D旋转。
.container .box:hover选择器用于在鼠标悬停在某个图片容器上时,该图片容器会放大并旋转。
实现原理
这段代码通过CSS的transform属性和transition属性实现了3D翻转结果。当鼠标悬停在容器上时,除了悬停的图片容器之外的其他图片容器会向两侧移动,并添加阴影结果和3D旋转。当鼠标悬停在某个图片容器上时,该图片容器会放大并旋转。
完整的代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style type="text/css">
/* 设置所有元素的边距和内边距为0,并设置box-sizing为border-box,使元素的宽度和高度包括边框和内边距 */
* {
margin: 0;
padding: 0;
box-sizing: border-box
}
/* 设置body的居中显示,最小高度为100vh,背景颜色为#1a252c */
body {
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background-color: #1a252c;
}
/* 设置容器的相对定位,居中显示,设置transform-origin为preserve-3d */
.container {
position: relative;
display: flex;
justify-content: center;
align-items: center;
transform-origin: preserve-3d;
}
/* 设置box的宽度、高度、相对定位、过渡效果、设置-webkit-box-reflect为下方1px的线性渐变 */
.container .box {
width: 300px;
height: 300px;
position: relative;
transition: .5s;
-webkit-box-reflect: below 1px linear-gradient(transparent, #0002);
}
/* 设置box的绝对定位,宽度、高度为100% */
.container .box img {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
/* 设置鼠标悬停时,非悬停元素的边距为-20px,设置filter为drop-shadow(0 0 25px #000) drop-shadow(0 0 25px #000),设置transform为perspective(500px) rotateY(45deg) scale(0.95) */
.container:hover> :not(:hover) {
margin: 0 -20px;
filter: drop-shadow(0 0 25px #000) drop-shadow(0 0 25px #000);
transform: perspective(500px) rotateY(45deg) scale(0.95);
}
/* 设置鼠标悬停时,box的兄弟元素的transform为perspective(500px) rotateY(-45deg) scale(0.95) */
.container .box:hover~.box {
transform: perspective(500px) rotateY(-45deg) scale(0.95);
}
/* 设置鼠标悬停时,box的transform为perspective(500px) rotateY(0) scale(1.2) */
.container .box:hover {
transform: perspective(500px) rotateY(0) scale(1.2);
}
</style>
</head>
<body>
<!-- 设置容器的class为container -->
<div class="container">
<!-- 设置box的class为box,并设置img的src为1.webp -->
<div class="box">
<img src="./1.webp" alt="" />
</div>
<!-- 设置box的class为box,并设置img的src为2.webp -->
<div class="box">
<img src="./2.webp" alt="" />
</div>
<!-- 设置box的class为box,并设置img的src为3.webp -->
<div class="box">
<div class="box">
<img src="./3.webp" alt="" />
</div>
</div>
<!-- 设置box的class为box,并设置img的src为4.webp -->
<div class="box">
<img src="./4.webp" alt="" />
</div>
<!-- 设置box的class为box,并设置img的src为5.webp -->
<div class="box">
<img src="./5.webp" alt="" />
</div>
<!-- 设置box的class为box,并设置img的src为6.webp -->
<div class="box">
<img src="./6.webp" alt="" />
</div>
</div>
</body>
</html>v>
<!-- 设置box的class为box,并设置img的src为4.webp -->
<div class="box">
<img src="./4.webp" alt="" />
</div>
<!-- 设置box的class为box,并设置img的src为5.webp -->
<div class="box">
<img src="./5.webp" alt="" />
</div>
<!-- 设置box的class为box,并设置img的src为6.webp -->
<div class="box">
<img src="./6.webp" alt="" />
</div>
</div>
</body>
</html>
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
李优秀
论坛元老
这个人很懒什么都没写!
楼主热帖
什么是API密钥及其安全利用指南? ...
基于GLM生成SQL,基于MOSS生成SQL,其 ...
【Java结业计划】基于JavaWeb的在线购 ...
Docker Compose - 安装和基本使用 ...
mac安装java17(jdk17)
【云原生 | 从零开始学Kubernetes】二 ...
亲测有效,彻底解决msvcr100.dll丢失的7 ...
[Qt][Qt 网络][下]具体讲解
Linux体系(CentOS)下安装设置 Nginx 超 ...
C#使用NModbus4库创建Modbus TCP Slave ...
标签云
AI
运维
CIO
存储
服务器
浏览过的版块
分布式数据库
数据安全
快速回复
返回顶部
返回列表