html div圆滑效果,如何使用CSS3的Animations实现平滑的页面加载

我对Apple.com产品页面上看到的一些微妙动画印象深刻。它通常以在页面加载时播放的动画开始,其中通过滑动/淡入在页面上引入元素。它是如此微妙,但对用户来说是如此令人满意。

最近,我发现了一些问题,即添加简单的动画效果而不会出现波动,从而破坏了体验。

在页面加载时播放动画的问题在于许多资源(包括操纵DOM的图像和脚本)导致浏览器重新绘制/重新布局。这在尝试播放动画时与浏览器资源竞争,导致丢帧。(推荐教程:css3视频教程)

一种解决方法是延迟动画的开始以允许在播放动画之前绘制页面。

通常在页面上引入/显示元素时,元素将被隐藏(不透明度:0),并且随着时间的推移会获得完全不透明度。

虽然动画属性有'delay'参数,但为此参数指定时间将在其最终帧中显示指定延迟长度的元素。然后它将隐藏元素,并将动画设置为完全不透明度。这是一种不希望的效果。我们不希望在延迟期间看到最后一个关键帧。

要避免在延迟期间看到该元素,请按照下列步骤操作:

1)在我们想要动画的html中创建一个div

2)在我们的css文件中创建关键帧(这些基本上将定义事物的变化,在这种情况下从不透明度0到不透明度100)

@keyframesfadeIn{from{opacity:0;}to{opacity:1;}}

3)在我们的css中创建div标签,定义我们的动画(持续时间,开始延迟等)并将其链接到我们的关键帧

.fade-in{

opacity:0;/*makethingsinvisibleuponstart*/

animation:fadeInease-in1;/*callourkeyframenamedfadeIn,useanimattionease-inandrepeatitonly1time*/

animation-fill-mode:forwards;/*thismakessurethatafteranimationisdoneweremainatthelastkeyframevalue(opacity:1)*/

animation-duration:1s;

animation-delay:1.5s}

关键是使用:

animation-fill-mode:forwards

opacity:0

结合,这会隐藏我们想要为指定延迟设置动画的元素(不透明度:0),并强制动画在最后一个关键帧上停止(不透明度:1)。

0rD44jyfZX4ASD83aX+fUoZpP4uDVd67o7TM6l7n7mq8tmrlP4Nfq9uFITcSGYAAAAASUVORK5CYII=

e3bae3dc05add31f46d7b4e77e53b9b1.png

本文转载自中文网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值