资讯专栏INFORMATION COLUMN

前端每日实战:36# 视频演示如何利用 CSS 动画原理,在页面上表现日蚀现象

张巨伟 / 1054人阅读

摘要:效果预览按下右侧的点击预览按钮可以在当前页面预览,点击链接可以全屏预览。可交互视频教程此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

效果预览

按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。

https://codepen.io/comehope/pen/OELvrK

可交互视频教程

此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

请用 chrome, safari, edge 打开观看。

https://scrimba.com/p/pEgDAM/cgnzMAz

源代码下载

每日前端实战系列的全部源代码请从 github 下载:

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,一个名为 sky 的容器,其中包含一个 sun 元素和一个 moon 元素:

</>复制代码

画出天空:

</>复制代码

  1. body {
  2. margin: 0;
  3. }
  4. .sky {
  5. width: 100vw;
  6. height: 100vh;
  7. background-color: skyblue;
  8. }

画出太阳:

</>复制代码

  1. .sky {
  2. display: flex;
  3. align-items: center;
  4. justify-content: center;
  5. position: relative;
  6. }
  7. .sun {
  8. position: absolute;
  9. width: 50vmin;
  10. height: 50vmin;
  11. border-radius: 50%;
  12. background-color: gold;
  13. }

画出月亮:

</>复制代码

  1. .moon {
  2. position: absolute;
  3. width: 50vmin;
  4. height: 50vmin;
  5. border-radius: 50%;
  6. background-color: slategray;
  7. transform: translateX(-55vmin);
  8. }

定义天空的变化,当日蚀来临时天空会变黑:

</>复制代码

  1. @keyframes animate-sky {
  2. 50% {
  3. background-color: black;
  4. }
  5. }

定义太阳的变化,当日蚀来临时太阳虽会被遮挡,但光晕仍会透出:

</>复制代码

  1. @keyframes animate-sun {
  2. 50% {
  3. box-shadow: 0 0 5em 1em white;
  4. }
  5. }

定义月亮的动画,当它运动到和太阳重叠的位置时,因为没有光,就看不到它的颜色了:

</>复制代码

  1. @keyframes animate-moon {
  2. from {
  3. transform: translateX(-100vmin);
  4. }
  5. 50% {
  6. background-color: black;
  7. }
  8. to {
  9. transform: translateX(100vmin);
  10. }
  11. }

把动画应用到元素上:

</>复制代码

  1. .sky,
  2. .sun,
  3. .moon {
  4. animation: 10s linear infinite;
  5. }
  6. .sky {
  7. animation-name: animate-sky;
  8. }
  9. .sun {
  10. animation-name: animate-sun;
  11. }
  12. .moon {
  13. animation-name: animate-moon;
  14. }

最后,隐藏滚动条:

</>复制代码

  1. .sky {
  2. overflow: hidden;
  3. }

大功告成!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/113391.html

相关文章

  • 前端每日实战36# 视频演示如何利用 CSS 动画原理页面表现日蚀现象

    摘要:效果预览按下右侧的点击预览按钮可以在当前页面预览,点击链接可以全屏预览。可交互视频教程此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。 showImg(https://segmentfault.com/img/bVbboHk?w=500&h=500); 效果预览 按下右侧的点击预览按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comeh...

    you_De 评论0 收藏0
  • 前端每日实战 2018 年 5 月份项目汇总(共 30 个项目)

    摘要:过往项目年月份项目汇总共个项目年月份发布的项目前端每日实战专栏每天分解一个前端项目,用视频记录编码过程,再配合详细的代码解读,是学习前端开发的活的参考书频演示如何用纯创作一种按钮被瞄准的交互特效视频演示如何用纯创作一个同心圆弧旋转特效视频演 过往项目 2018 年 4 月份项目汇总(共 8 个项目) 2018 年 5 月份发布的项目 《前端每日实战》专栏每天分解一个前端项目,用视频记录...

    array_huang 评论0 收藏0
  • 前端每日实战 2018 年 5 月份项目汇总(共 30 个项目)

    摘要:过往项目年月份项目汇总共个项目年月份发布的项目前端每日实战专栏每天分解一个前端项目,用视频记录编码过程,再配合详细的代码解读,是学习前端开发的活的参考书频演示如何用纯创作一种按钮被瞄准的交互特效视频演示如何用纯创作一个同心圆弧旋转特效视频演 过往项目 2018 年 4 月份项目汇总(共 8 个项目) 2018 年 5 月份发布的项目 《前端每日实战》专栏每天分解一个前端项目,用视频记录...

    liaoyg8023 评论0 收藏0

发表评论

0条评论

张巨伟

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<