【每日一练】89—一个滑动卡片动画UI效果的实现
web前端开发
共 3666字,需浏览 8分钟
· 2022-11-01
写在前面
已经有两天没有更新小练习了,希望大家没有忘记自我练习,保持一种持续学习的习惯很重要。
今天我们一起来练习一个滑动卡片效果,这种卡片式的UI效果,我们在前面的练习中也分享了不少。
但今天这个练习采用了折叠滑动式的设计,这种设计的好处就是,占用页面空间小,对于一些内容多的页面,这种效果是非常实用,现在,我们就一起来看一下它的最终效果:
<html>
<head>
<meta charset="UTF-8">
<title>【每日一练】89—一个滑动卡片动画UI效果的实现</title>
</head>
<body>
<div class="card">
<div class="contentBx">
<div class="content">
<h2>web前端开发<br><span>一个前端开发设计公众平台</span></h2>
<div class="imgBx">
<img src="img.png">
</div>
<button>欢迎关注</button>
</div>
</div>
<div class="toggle">
<span></span>
</div>
</div>
<script>
let card = document.querySelector('.card');
let cardtoggle = document.querySelector('.toggle');
cardtoggle.onclick = function(){
card.classList.toggle('active');
};
</script>
</body>
</html>
*
{
margin: 0;
padding: 0;
box-sizing: border-box;
font-family: 'Poppins', sans-serif;
}
body
{
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background: #fff;
}
.card
{
position: relative;
width: 350px;
height: 85px;
background: #00a6bc;
border-radius: 20px;
transition: 0.5s ease-in-out;
filter: drop-shadow(-20px 20px 40px #00a6bc);
}
.card.active
{
height: 420px;
}
.toggle
{
position: absolute;
left: 50%;
transform: translate(-50%);
bottom: -60px;
width: 70px;
height: 60px;
border-bottom-left-radius: 35px;
border-bottom-right-radius: 35px;
background: #00a6bc;
cursor: pointer;
}
.toggle::before
{
content: '';
position: absolute;
left: -34px;
width: 35px;
height: 35px;
background: transparent;
border-top-right-radius: 35px;
box-shadow: 11px -10px 0 10px #00a6bc;
}
.toggle::after
{
content: '';
position: absolute;
right: -34px;
width: 35px;
height: 35px;
background: transparent;
border-top-left-radius: 35px;
box-shadow: -11px -10px 0 10px #00a6bc;
}
.toggle span
{
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%,-70%) rotate(405deg);
width: 10px;
height: 10px;
border-bottom: 3px solid #fff;
border-right: 3px solid #fff;
transition: 0.5s;
}
.card.active .toggle span
{
transform: translate(-50%,-70%) rotate(225deg);
}
.contentBx
{
position: absolute;
inset: 0;
overflow: hidden;
}
.content
{
position: relative;
padding: 20px;
text-align: center;
z-index: 10;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.content h2
{
color: #fff;
font-weight: 500;
font-size: 1.25em;
text-transform: uppercase;
letter-spacing: 0.05em;
line-height: 1.1em;
}
.content h2 span
{
font-size: 0.75em;
font-weight: 400;
letter-spacing: 0.05em;
text-transform: initial;
}
.imgBx
{
position: relative;
width: 250px;
height: 250px;
background: #fff;
margin-top: 20px;
overflow: hidden;
border: 5px solid #fff;
box-shadow: -10px 10px 10px rgba(0,0,0,0.15);
pointer-events: none;
}
.imgBx img
{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: cover;
}
.content button
{
position: relative;
margin-top: 20px;
padding: 10px 35px;
border-radius: 25px;
border: none;
outline: none;
cursor: pointer;
box-shadow: -10px 10px 10px rgba(0,0,0,0.15);
font-size: 1em;
text-transform: uppercase;
letter-spacing: 0.1em;
font-weight: 500;
color: #333;
}
写在最后
以上就是今天我跟大家分享的【每日一练】全部内容,希望今天的小练习对你有用,如果你觉得有帮助的话,请点赞我,关注我,并将它分享给你身边做开发的朋友,也许能够帮助到他。
我是杨小爱,我们明天见。
学习更多技能
请点击下方公众号
评论
了解加密货币到加密货币的互换
1、什么是加密货币互换?加密货币到加密货币的互换是指以现行市场汇率将一种加密货币直接兑换为另一种加密货币。与需要法定货币存款和较长流程的传统交易所不同,加密货币到加密货币的互换可以无缝地促进交换。掉期在提高加密货币的流动性和效率方面发挥着重要作用。该功能使用户能够将他们的加密货币与钱包中的其他代币进
区块链头条
0
用 Shader 实现旗帜飘扬动画效果
我觉得对于刚入门 3D 编程的朋友来说,如果能够完成代码创建模型数据->创建材质->编写Shader动画这一系列,想必会有满满的成就感。今天就用 Cocos Creator 的 utils.MeshUtils.createMesh 接口,带大家感受一下这个流程。这个流程不仅可以用于新手学
COCOS
2
【第129期】程序员的新宠:三款终端工具,让你告别Xshell!
概述 WindTerm:跨平台的SSH利器 首先介绍的是WindTerm,这是一款使用C语言开发的跨平台SSH客户端。它不仅完全免费,而且没有商业使用的限制。WindTerm支持SSH v2、Telnet、Raw Tcp等协议,而且性能出色,甚至超过了FinalShell和Electerm。功能
前端微服务
0
上班的时候,有一群摸鱼搭子非常重要...
上班的时候,有一群摸鱼搭子非常重要!一到上班时间,他们就从四面八方涌进群里冒泡...从八卦聊到股市、从职场聊到乌X兰局势,偶尔还会复读、相亲、battle...然后,下午6点钟准时消失不见...所以你要不要加入我们一起摸鱼?我们有北京、上海、深圳、广州、杭州、武汉、成都、南京等8个城市的摸鱼群,还有
产品经理日记
0
周四002 瑞超:同样落寞的境遇——北雪平vs埃尔夫斯堡
上赛季最终排名联赛第9的北雪平本赛季伊始表现不佳,4轮战罢他们仅以1胜1平2负的战绩排在倒数第三,这支历史上曾夺得13次联赛冠军、6次杯赛冠军老牌劲旅,正如英格兰赛场上的一众百年俱乐部,在低谷中不断探索着出路。球队主教练安德烈亚斯·阿尔姆曾是AIK索尔纳及赫根队的主教练,他于今年年初刚刚拿起球队教鞭
产品与体验
0
日本影山优佳最新杂志照,展现充满透明感的美丽
今天的图文分享的是影山优佳的杂志写真。元日向坂46的影山优佳,登上了写真杂志《周刊FLASH》5/7和5/14合并号的封面。影山优佳是日本艺人、女演员、前偶像。身高155厘米。2001年5月8日出生于东京都。2023年7月从组合日向坂46毕业,之后作为演员活跃的影山优佳,在《周刊FLAS
python教程
0
盘点一个使用超级鹰识别验证码并自动登录的案例
点击上方“Python共享之家”,进行关注回复“资源”即可获赠Python学习资料今日鸡汤江上几人在,天涯孤棹还。大家好,我是皮皮。一、前言前几天在Python钻石交流群【静惜】问了一个Python实现识别验证码并自动登录的问题,提问截图如下:验证码的截图如下所示:二、实现过程这里大家激烈的探讨,【
IT共享之家
0
朋友,你也不想一个人孤孤单单的上班吧?
上班的时候,有一群摸鱼搭子非常重要!一到上班时间,他们就从四面八方涌进群里冒泡...从八卦聊到股市、从职场聊到乌X兰局势,偶尔还会复读、相亲、battle...然后,下午6点钟准时消失不见...所以你要不要加入我们一起摸鱼?我们有北京、上海、深圳、广州、杭州、武汉、成都、南京等8个城市的摸鱼群,还有
产品经理日记
0