背景
最近一段时间做了几个需求,其中涉及的素材列表展示,需要实现类似下方图片中的动效,暂且称之为【卡片放大播放动效】,具体细节如下:
初始展示的是封面图片,鼠标经过时是视频放大的效果;下方文字内容区域,在放大前后展示的内容不同,而且两者的字体大小是一致的,不是简单的放大实现;四五个页面都需要实现相同列表效果,列表的行数和列数是不一致的;在整个实现过程中,遇到以下四个问题,后面的解析中会有对应解答。
(相关资料图)
这个动效,在爱奇艺官网也有类似效果,爱奇艺官网是通过生成初始状态卡片列表和鼠标放大卡片列表两套列表,然后通过动态计算放大卡片位置,相对于body进行绝对定位展示的。
本实现方案通过将卡片初始状态和放大状态,封装到一个组件中,通过两者间的相对关系,利用css自动完成对应关系,避免了大量的JS计算。
1. 放大效果实现UI对该动效的要求实际就是鼠标视频放大播放,如果卡片初始状态也放置视频video,通过transition对同一元素进行scale放大也可以实现,但是这是一个列表,用户进入页面,就会同时加载多个视频,用户体验不是很好。
所以,实现方案就是卡片初始状态放置poster图片,鼠标经过时,在poster上方展示视频层(绝对定位),然后对视频执行animation动画来模拟放大效果。
卡片底部文字区域如何处理?
由于卡片初始状态下,底部文字区域在列表布局中是占位的,所以在卡片初始状态下,底部文字区域使用正常文档流。
卡片鼠标经过状态下,视频层的放大效果是以poster中心点为放大原点的,所以底部文字区域使用absolute定位,相对于player进行定位处理。
interfaceIItemData{src?:string;poster?:string;industry?:string;}interfaceIProps{posterClass:string;//poster区域宽高playerClass:string;//放大后视频宽高样式itemData:IItemData;children:{[key:string]:any};}lett:NodeJS.Timeout;constVideoItem:FC=({posterClass,playerClass,itemData,children,})=>{const[isHover,setIsHover]=useState(false);constonMouseEnter=()=>{t=setTimeout(()=>{//避免快速移动鼠标,造成视频无法隐藏问题setIsHover(true);},50);};constonMouseLeave=()=>{clearTimeout(t);setIsHover(false);};return( Top1
.container{position:relative;.poster{position:relative;background-position:center;background-size:cover;background-repeat:no-repeat;.player{z-index:10;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(0.929);animation:showPlayer0.2sease;animation-fill-mode:forwards;.playerBottom{width:100%;position:absolute;top:100%;left:0;box-shadow:0px6px16px-8pxrgba(0,0,0,0.08),0px12px48px16pxrgba(0,0,0,0.03);filter:drop-shadow(0px9px28pxrgba(0,0,0,0.05));}}}.posterBottom{width:100%;}}@keyframesshowPlayer{0%{transform:translate(-50%,-50%)scale(0.929);}100%{transform:translate(-50%,-50%)scale(1);}}2. 抽离为通用组件时,卡片底部文字区域如何动态替换
整个卡片组件,底部的文字区域在不同的场景下可能是不同的,所以作为通用性组件,需要将这部分抽离,支持动态替换。
vue中最简单的方式,就是插槽,通过插槽从外部动态传入。但是react框架是不支持具名插槽的。所以,这个问题就转换成了,react如何实现具名插槽?
网上搜到了一种实现方式,通过传入一个object来实现,具体效果如下:
//cardList{{posterBottom:bottomInfo,playerBottom:bottomInfo,onClickPlayer:()=>{consturl=`${window.location.origin}/#/market/service/${item.itemId}`;window.open(url,"_blank");},}}//VideoItem {props.children?.playerBottom} {props.children?.posterBottom}
当然,具名插槽还有其它的实现方式,后面会专门写一篇文章总结学习下。
3. 列表容器如果是弹性布局时,每行的列数无法固定,flex布局无法满足这个问题是一个通用性问题,在容器宽度不固定时,flex布局,每行最后一个元素无法选中设置样式,同时子元素个数不固定时,最后一行元素的间距会变大。
这种情况下,就需要grid布局大显身手了,以前很少用grid布局,这次也是学习到了,具体效果如下图:
在示例中,调整浏览器窗口大小,来实验弹性布局观看效果代码片段
目前放大效果的实现方式,放大的视频层是绝对定位的,参照物是每个卡片本身。所以在四周边界处的卡片,放大后,很容易被容器给遮盖。
处理方式也很简单,给容器多设置一些padding,让放大部分足够展示,然后用margin设置负值来调整布局
.container{margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px;}总结
每个产品需求里,可能都会隐藏着自己的盲点,将效果做到极致,就能获得技术成长。在重复的需求里,多反思总结,寻找自己的提升点,这就是进步吧啊。
相关推荐1.CSS 实现按钮点击动效的套路
2.年份数字拼图效果
3.跑马灯简单版
4.中心点靠近动画解析
中原网讯(记者于露刘梦琳通讯员李学莉汤永浩)电影是浓缩的艺术表现形式
根据微软自己的说法:MicrosoftValidationOS是一种轻量级、快速且可自
又有A股公司实控人被留置。7月3日早盘,国内医疗健康信息化解决方案的
一、长沙至岳阳旅游价格是多少钱坐高铁出发的话,从长沙南到岳阳东是30
摘要:2023年07月03日邦彦技术(688132)换手率大于8%,主力资金净流出
你们好,最近小活发现有诸多的小伙伴们对于卡通车简笔画图片大全,卡通
吉林市养殖的手续流程吉林市养殖的手续流程包括以下几个步骤:申请人需
2023年四川养老金上调方案今日还未公布。自2023年5月22日人社部下发202
1、你好。2、如果是自己弄伤的话没有等级的如果是工伤的话也没有等级的
1、国际快递有很多,国内主流的有DHL UPS TNT 易起运等等很多的。2、哪
6月29日至7月2日,三亚市旅游发展局连续第4年来到成都,面向旅业和市民
据美联社报导,以色列国防部7月2日宣布,以色列将从美国购买25架F-35战
2023杭州中考第二批录取分数线公布第一批最低录取控制分数线为511分。
噩耗突然传来。 胡德霖突然离世,或许意味着,江苏豪门“父子内斗”落
1、迅捷流程图制作软件就可以在线画流程图,而且在线画流程图的方法有
图为6月30日,该局幸福监管所检查人员对食品进行抽查。食品安全无小事
2023年7月3日8:57 来源:重庆日报
“我们公司13个沿街门店全部参加晚报发起的‘关爱从一杯水开始’公益活
中央气象台7月3日06时继续发布暴雨蓝色预警:预计,7月3日08时至4日08
1、《文言文全解一本通》是2020年山东人民出版社出版的图书,作者是梁
中国置业投资(00736)发布公告,于2020年6月1日,公司全资附属公司上海祥宸
歌力思 小而美的多品牌时装集团逆势拓张彰显信心 东北证券6月30
中评社北京7月3日电(记者 李子宁 海涵 助理记者 徐媛 赵海欣
7月1日是党的生日。党员是党的肌体的细胞,如何做一名合格的共产党员?
1、气液增压泵工作原理类似于压力增压器,对大径空气驱动活塞施加一个
本文讨论的话题是汽车的开窗通风。本文基于CFD对小轿车在不同开窗情况
定西市始终把大力培育乡村工匠、发展庭院经济作为人才振兴、产业振兴的
大河网讯小井盖,大民生。自2021年河南省城市公共区域窨井盖专项整治三
7月2日,新强联公告,因财务资料过期,深交所中止审核新强联拟收购洛阳
据悉,在萨卡里之前,唯一进入过女单世界前20的希腊女球员是埃莱尼·达
Copyright © 2015-2032 潇湘服装网版权所有 备案号:琼ICP备2022009675号-41 联系邮箱: 435 227 67@qq.com