当前位置:首页>新闻 > >正文

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

  • 2023-01-11 07:20:11来源:程序员客栈

背景

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

初始展示的是封面图片,鼠标经过时是视频放大的效果;下方文字内容区域,在放大前后展示的内容不同,而且两者的字体大小是一致的,不是简单的放大实现;四五个页面都需要实现相同列表效果,列表的行数和列数是不一致的;
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.中心点靠近动画解析

标签: 初始状态 绝对定位 这个问题

延伸阅读

推荐阅读

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

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

重庆渝康码红码怎么转绿?-天天微资讯

渝康码红码怎么转绿?对确诊病例和无症状感染者赋红码。转码规则:确诊病例和无症状感染者——出院(舱)后转绿码或连续两次核酸检测阴性(两次...

停牌核查!11天收出6个涨停板,全聚德股价暴涨背后业绩如何支撑?

2020年以来,全聚德推出多项经营改革措施,并加大预制菜业务投入,但2020年至2021年以及2022年前三季度,全聚德已累计净亏6 42亿元《投资时报》研究员

东易日盛(002713):独立董事关于第五届董事会第十八次(临时)会议相关事项的独立意见_世界热消息

东易日盛家居装饰集团股份有限公司独立董事关于第五届董事会第十八次(临时)会议相关事项的独立意见根据中国证监会《上市公司独立董事规则》

世界快资讯:九州一轨: 九州一轨首次公开发行股票并在科创板上市网上发行申购情况及中签率公告

九州一轨:九州一轨首次公开发行股票并在科创板上市网上发行申购情况及中签率公告

2022盘锦七级工伤怎么计算-环球快资讯

职工因工致残被鉴定为七级至十级伤残的,享受以下待遇:(一)从工伤保险基金按伤残等级支付一次性伤残补助金,标准为:七级伤残为13个月的本

11只ETF公告上市 最高仓位76.67%

上投摩根中证碳中和60ETF今日发布上市公告书,基金将于2023年1月13日上市,上市交易份额为3 47亿份,该基金成立日为2022年12月29日,截至2023

百事通!宜人贷网贷14万逾期会面临起诉吗

可能会。如果用户使用网贷消费之后出现了逾期,并且经过网贷机构和第三方的催收人员催缴欠款无果之后,网贷公司可能就会向法院提起诉讼。网贷

易借速贷逾期15年延迟还款征信有什么影响

网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可

NBA :目前多达13人场均出手超过20次,他们场均得分一览,不错

NBA:目前多达13人场均出手超过20次,他们场均得分一览,不错,勒布朗詹姆斯,库里,布克,阿德托昆博,布朗,鲍尔

“乙类乙管”首日探访出入境口岸:取消核酸检测 人员高效通关_环球快看

“乙类乙管”实施首日,在杭州出入境边检查验大厅,入境旅客正有序办理通关手续。杭州出入境边检站执勤四队教导员李小飞介绍,“乙类乙管”...

看月上重火穆远笑着退场,4件事成功洗白,却惹得观众飙泪-快讯

关注我,给你一个不一样的影视生活。看《月上重火》,最开心的是见证上官透与重雪芝的百年之好,最伤心的就是看宇文穆远笑着挥手下场。相比原

CES 2023 TCL华星携多款黑科技产品惊艳亮相

近日,国际消费类电子产品展览会(简称“CES”)在美国举办。CES是世界上最大、影响最为广泛的消费类电子技术年展,也是全球最大的消费技术...

苏宁任性贷网贷逾期十天延迟还款征信会怎么样

网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可

当前视讯!戴高乐之孙:美国通过加剧俄乌冲突、对俄发动经济战争,让欧洲人受苦

综合俄新社和今日俄罗斯电视台(RT)网站4日报道,法国前总统戴高乐之孙皮埃尔·戴高乐认为,通过加剧俄乌冲突,并对俄罗斯发动一场事先计...

天天微动态丨国内伪专家提议春节禁放的烟花爆竹,韩国却要拿来申遗!

1988年,专家张玄武为了迎合国家治理大气污染环境问题,首先提出了全国春节期间禁止燃放烟花爆竹的建议。之后,另外一位

房地产开发板块跌1% 数源科技涨10%居首 每日播报

中国经济网北京1月5日讯今日,房地产开发板块整体跌幅1 00%,其中22只股票上涨,4只股票平盘,78只股票下跌。

【焦点热闻】润建股份:控股子公司参与恒运电力增资扩股

证券时报e公司讯,润建股份1月5日晚间公告,公司控股子公司泺立能源以公开摘牌方式参与穗恒运A(000531)子公司恒运电力增资扩股,以自有资金352

宏达电子:融资净买入274.01万元,融资余额2.06亿元(01-05)

2023年1月5日宏达电子融资净买入274 01万元,融资余额2 06亿元

2023重庆国际光影艺术节光影秀可以现场看吗?-环球讯息

2023重庆国际光影艺术节光影秀可以现场看吗?可以。光影艺术节现场秀时间:2023年1月6日—10日*具体灯光秀每日表演时间暂未公布,小编将持续关

手势识别板块1月5日涨0.72%,鸿合科技领涨,主力资金净流入1672.3万元_世界新动态

1月5日手势识别板块较上一交易日上涨0 72%,鸿合科技领涨。当日上证指数报收于3155 22,上涨1 01%。深证成指报收于11332 01,上涨2 13%。手势

环球快播:沙湖公园藏着一片芦苇荡

沙湖公园藏着一片芦苇荡

每日快报!积极开展自然资源节约集约示范县(市)创建 河北提出十条支持政策

为积极开展自然资源节约集约示范县(市)创建,河北省自然资源厅近日出台《河北省自然资源节约集约示范县(市)创建支持政策》(以下简称《支

【全球报资讯】尼泊尔的卡拉帕尼地区,如何被印度侵占?

印度是南亚地区最大的国家,分别和我国、巴基斯坦、孟加拉国等多个国家接壤,首都为新德里。印度和巴基斯坦、孟加拉国,历史上都是英属印度的

焦点速递!民调显示:多数美国人对今年前景感到悲观

美国盖洛普公司当地时间1月3日公布的最新民调结果显示,大多数美国人对美国2023年的前景持悲观态度,约八成受访美国民众认为2023年将是美国经

焦点消息!海口警方通报“男子持械打砸超市”案情:对嫌疑人谢某处以15日行拘

当日19时42分,秀英派出所接报警后,于19时47分到达现场,当场控制违法嫌疑人谢某(男,60岁)后对其依法处以行政拘留十五日处罚,对投案自首的

去年12月份混基跌幅前7名长安基金占6只 均跌逾13% 快播报

去年12月份混基跌幅前7名长安基金占6只均跌逾13%

全球观热点:用“预案”守护好节日“烟火气”

网评:用“预案”守护好节日“烟火气”   来源:东方网 作者:丁慎毅  百万网友涌入直播间,在淘宝直播看烟花、追日出成跨年新仪式;...

“我来当市民骑手”-世界新视野

近日,甘肃省嘉峪关市外卖小哥冒雪奔波在寒冷的风雪中运送生活物资。图为嘉峪关市外卖小哥行走在运送居民生活物资的风雪路上。  马玉福摄(

世界微资讯!招金矿业签订地质勘查相关服务框架协议及物资采购框架协议

招金矿业(01818)公布,于2023年1月3日,山东招金地质与招金集团订立地质勘查相关服务框架协议,内容有关山东招金地质于2023年1月1日至2025年12

猜您喜欢

Copyright ©  2015-2022 南方服装网版权所有  备案号:粤ICP备18023326号-21   联系邮箱:855 729 8@qq.com