当前位置: 首页>行业 >

卡片放大播放效果实现总结,不同元素间的放大过渡效果如何实现?

来源: 程序员客栈 | 时间: 2023-01-10 21:23:52 |

背景

最近一段时间做了几个需求,其中涉及的素材列表展示,需要实现类似下方图片中的动效,暂且称之为【卡片放大播放动效】,具体细节如下:

初始展示的是封面图片,鼠标经过时是视频放大的效果;下方文字内容区域,在放大前后展示的内容不同,而且两者的字体大小是一致的,不是简单的放大实现;四五个页面都需要实现相同列表效果,列表的行数和列数是不一致的;
image
遇到的四个问题

在整个实现过程中,遇到以下四个问题,后面的解析中会有对应解答。


(资料图)

不同元素间的放大过渡效果如何实现?抽离为通用性组件时,如何实现类vue中的具名插槽效果,来替换下方文字信息区域?不同页面中的列表区域宽度不同,有的页面列表还是弹性宽度,常用的flex布局无法满足要求,如何实现呢?边界卡片放大后,如何避免被父级列表容器overflow:hidden`隐藏掉?实现解析

这个动效,在爱奇艺官网也有类似效果,爱奇艺官网是通过生成初始状态卡片列表和鼠标放大卡片列表两套列表,然后通过动态计算放大卡片位置,相对于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
{isHover?({children?.playerBottom}
):null}
{children?.posterBottom});};exportdefaultVideoItem;

.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布局,这次也是学习到了,具体效果如下图:

在示例中,调整浏览器窗口大小,来实验弹性布局观看效果代码片段

image.png
4. 卡片放大后,可能会被容器设置的overflow:hidden给遮盖隐藏掉

目前放大效果的实现方式,放大的视频层是绝对定位的,参照物是每个卡片本身。所以在四周边界处的卡片,放大后,很容易被容器给遮盖。

处理方式也很简单,给容器多设置一些padding,让放大部分足够展示,然后用margin设置负值来调整布局

.container{margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px;}

总结

每个产品需求里,可能都会隐藏着自己的盲点,将效果做到极致,就能获得技术成长。在重复的需求里,多反思总结,寻找自己的提升点,这就是进步吧啊。

相关推荐

1.CSS 实现按钮点击动效的套路

2.年份数字拼图效果

3.跑马灯简单版

4.中心点靠近动画解析

关键词: 初始状态 绝对定位 这个问题

 

热文推荐

透视雪佛兰大降价的幕后:销量低迷,八月无一辆车的销量破万

继上汽通用别克开启限时优惠之后,雪佛兰也按捺不住了。科鲁泽(参数|询

2023-09-09

茵郁道馆(关于茵郁道馆简述)

,你们好,今天0471房产来聊聊一篇郁道馆,郁道馆简述的文章,网友们对

2023-09-09

“这学还怎么上”?某小学开学一年级有43个班,家长哭诉卷不动了

“这学还怎么上”?某小学开学一年级有43个班,家长哭诉卷不动了,初中,

2023-09-09

夏东豪身高(夏东豪和谁牵手成功)

来为大家解答以上的问题。夏东豪身高,夏东豪和谁牵手成功这个很多人还

2023-09-09

莲台寺(关于莲台寺的简介)

1、莲台寺始建于唐朝,几经兴衰,因唐高僧智诜和尚曾主持莲台寺,在国

2023-09-09

首日产生14枚金牌!2023年全国青年(U20)田径锦标赛在我市开赛

9月8日上午2023年全国青年(U20)田径锦标赛在大庆市体育场开赛据了解

2023-09-09

“叫我们大队的人来”,女子理发店亮证件威胁老板!官方通报

据@郯城发布微博,郯城县联合调查组发布9月8日情况通报称,针对网传“

2023-09-08

龙虎榜|蓝英装备今日涨停,上榜营业部席位合计净买入9230.88万元

9月8日,蓝英装备今日涨停,龙虎榜数据显示,上榜营业部席位全天成交1

2023-09-08

古代皇帝用什么语言

古代皇帝用什么语言1、古代皇帝用什么语言当时的官话,也是官方语言;

2023-09-08

又大跌!再度跌破20万

碳酸锂又处于新一轮价格下滑周期中。

2023-09-08

记录走过半个世纪的爱情,金山石化街道开展“金婚摄影”活动

“叔叔,再靠近阿姨一点”“阿姨,动作再俏皮一点,对,看镜头!”随着

2023-09-08

苦茶随笔(关于苦茶随笔简述)

,你们好,今天0471房产来聊聊一篇茶随笔,茶随笔简述的文章,网友们对

2023-09-08

河南修武县属于哪个市(焦作修武县地理位置及经济发展情况)

河南修武县作为焦作市的一个县级行政区,处于中部偏东区域,是河南省发

2023-09-08

第十一届环鄱赛开赛 30多个国家及港澳台地区选手参赛

中新网上饶9月8日电 (记者 吴鹏泉)第十一届环鄱阳湖国际自行车大

2023-09-08

iPhone 15系列曝光:15 Plus首发4800万主摄

iPhone15系列即将发布,据新爆料,该系列将有三种不同的影像规格。iPhone

2023-09-08

电脑自带的酷狗音乐是在哪个盘里_电脑酷狗怎么在我的电脑显示酷狗音乐云盘

电脑自带的酷狗音乐是在哪个盘里,电脑酷狗怎么在我的电脑显示酷狗音乐

2023-09-08

佛山五区均升级暴雨红色预警:各中小学、幼儿园已停课,部分景区已闭园

南方财经全媒体记者吴蓉佛山报道受台风“海葵”残余环流和季风影响,9

2023-09-08

谭惜陆离电视剧完结了吗

谭惜和陆离结婚三年,这三年里,陆离身边的女人从未重复过,直到谭惜和

2023-09-08

北京再推介近2000亿元项目引资民间

从引入民间资本参与方式看,民间资本参与方式更加多元化。具体来看,民

2023-09-08

首脑(首脑)

导读1、词语:首脑拼音:shǒunǎo词性:名词近义词:元首、领袖、首领

2023-09-01

资讯

胡松辉:澳门特区正在努力争取承办CBA赛事

昨晚,第六届粤澳杯第二回合的比赛在恩平体育中心落下帷幕,广东队以89∶77赢下比赛。两回合比赛,广东队以177∶160的优势获得本届比赛的冠

2022-07-08     
北京推出14条秋游文化线路

金秋时节,北京市文化和旅游局以赏银杏品文化为主题,推出14条“叶落的季节——漫步北京赏银杏品文化主题线路”,邀市民和游客以步行、骑行

2021-10-27     
基因编辑发力 培育高质量人源化供体猪

此次人体试验,仅仅验证了基因编辑猪克服异种器官移植的超急性排斥反应,还需解决延迟性排斥反应、消耗性血栓等问题。但通过这次试验,能更

2021-10-27     
中国经济高质量发展步伐稳健 长期向好基本面未变

在全球疫情走势和经济走势趋于复杂的背景下,中国经济巨轮将驶向何方,举世关注。2020年10月26日至29日,党的十九届五中全会在京举行,明确

2021-10-27     
南美解放者杯决赛允许近4.5万观众入场

南美洲足联主席多明格斯25日与今年解放者杯决赛对阵的两支俱乐部负责人会晤,宣布决赛现场观众人数增加到球场容量的75%,即近4 5万人。今年

2021-10-27     
22年从警生涯 面对荣誉他说不要给我报功

9月24日,时任安徽省安庆市公安局迎江分局刑警大队大要案中队中队长周磊因在工作中激烈搏斗引发心源性猝死,倒在了工作岗位上,经医院抢救

2021-10-27