效果预览

在线演示

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

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

可交互视频教程

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

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

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

源代码下载

本地下载

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

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

代码解读

定义 dom,容器中包含左拍、小球和右拍:

  1. <div class="court">
  2. <div class="left-paddle"></div>
  3. <div class="ball"></div>
  4. <div class="right-paddle"></div>
  5. </div>

居中显示:

  1. body {
  2. height: 100vh;
  3. display: flex;
  4. align-items: center;
  5. justify-content: center;
  6. background: linear-gradient(silver, dimgray);
  7. }

调整盒模型:

  1. * {
  2. box-sizing: border-box;
  3. }

画出球案:

  1. .court {
  2. width: 20em;
  3. height: 20em;
  4. color: white;
  5. border: 1em solid currentColor;
  6. }

画出左拍:

  1. .court {
  2. position: relative;
  3. }
  4. .left-paddle
  5. width: 1em;
  6. height: calc(50% - 1em);
  7. background-color: currentColor;
  8. position: absolute;
  9. top: 1em;
  10. left: 1em;
  11. }

让左拍动起来:

  1. .left-paddle {
  2. animation: left-moving 1s linear infinite alternate;
  3. }
  4. @keyframes left-moving {
  5. to {
  6. transform: translateY(100%);
  7. }
  8. }

类似地,画出右拍:

  1. .right-paddle
  2. width: 1em;
  3. height: calc(50% - 1em);
  4. background-color: currentColor;
  5. position: absolute;
  6. top: 1em;
  7. left: 1em;
  8. bottom: 1em;
  9. right: 1em;
  10. }

类似地,让右拍动起来:

  1. .right-paddle {
  2. animation: right-moving 1s linear infinite alternate;
  3. }
  4. @keyframes right-moving {
  5. to {
  6. transform: translateY(-100%);
  7. }
  8. }

画出小球:

  1. .ball {
  2. width: 100%;
  3. height: 1em;
  4. border-left: 1em solid currentColor;
  5. position: absolute;
  6. left: 2em;
  7. top: calc(50% - 1.5em);
  8. }

让小球动起来:

  1. .ball {
  2. animation: bounce 1s linear infinite alternate;
  3. }
  4. @keyframes bounce {
  5. to {
  6. left: calc(100% - 3em);
  7. }
  8. }

最后,重构一下左右拍的代码,合并共有属性:

  1. .left-paddle,
  2. .right-paddle {
  3. width: 1em;
  4. height: calc(50% - 1em);
  5. background-color: currentColor;
  6. position: absolute;
  7. animation: 1s linear infinite alternate;
  8. }
  9. .left-paddle {
  10. top: 1em;
  11. left: 1em;
  12. animation-name: left-moving;
  13. }
  14. .right-paddle {
  15. bottom: 1em;
  16. right: 1em;
  17. animation-name: right-moving;
  18. }

大功告成!

原文地址:https://segmentfault.com/a/1190000015002553

如何利用 CSS 的动画原理,创作一个乒乓球对打动画的更多相关文章

  1. 前端每日实战:31# 视频演示如何利用 CSS 的动画原理,创作一个乒乓球对打动画

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/rvgLzK 可交互视频教程 此视频 ...

  2. 31.用 CSS 的动画原理,创作一个乒乓球对打动画

    原文地址:https://segmentfault.com/a/1190000015002553 感想:纯属动画 HTML代码: <div class="court"> ...

  3. 利用CSS实现带相同间隔地无缝滚动动画

    说明:因为在移动上主要利用CSS来做动画,所以没有考虑其他浏览器的兼容性,只有-webkit这个前缀,如果需要其他浏览器,请自行补齐. 首先解释一下什么是无缝滚动动画, 例如下面的例子 See the ...

  4. 51.纯 CSS 创作一个雷达扫描动画

    原文地址:https://segmentfault.com/a/1190000015283286 感想:linear-gradient() 刷新了我的认知,它可以并列多个而不会被覆盖,并列使用时用 , ...

  5. 42.纯 CSS 创作一个均衡器 loader 动画

    原文地址: https://segmentfault.com/a/1190000015157160 感想: 不难,最简单的动画.拓展地址: https://scrimba.com/c/cWqVv9hd ...

  6. 如何用纯 CSS 创作一个菱形 loader 动画

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/eKzjqK 可交互视频教 ...

  7. 前端每日实战:45# 视频演示如何用纯 CSS 创作一个菱形 loader 动画

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/eKzjqK 可交互视频教程 此视频 ...

  8. 45.纯 CSS 创作一个菱形 loader 动画

    原文地址:https://segmentfault.com/a/1190000015208027#articleHeader3 感想: 网格布局-> display: grid; HTML co ...

  9. 如何用纯 CSS 创作一个变色旋转动画

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/ejZWKL 可交互视频 ...

随机推荐

  1. JavaWeb_(Hibernate框架)Hibernate配置文件hibernate.cfg.xml

    hibernate.cfg.xml配置文件——链接数据库 hibernate.cfg.xml一定要配置在/src文件目录下 --数据库驱动,url,用户名,密码 --方言org.hibernate.d ...

  2. 费马小定理证明 (copy的,自己捋清楚)

    费马小定理:假如p是质数,且gcd(a,p)=1,那么 a^(p-1)≡1(mod p) 证明(copy的百度百科,加点自己的解释) 引理1. 若a,b,c为任意3个整数,m为正整数,且(m,c)=1 ...

  3. 解决Vue刷新一瞬间出现样式未加载完或者出现Vue代码问题

    解决Vue刷新一瞬间出现样式未加载完或者出现Vue代码问题: <style> [v-cloak]{ display: none; } </style> <div id=& ...

  4. canvas基础知识点(一)

    给canvas设置宽高: canvas标签的宽高默认是300*150,是一个行内块元素 可以在canvas标签上通过width,height来设置 可以在js中给dom对象设置: mycanvas.w ...

  5. leetcode题目17.电话号码的字母组合(中等)

    题目描述: 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合. 给出数字到字母的映射如下(与电话按键相同).注意 1 不对应任何字母. 示例: 输入:"23"输出: ...

  6. axios的拦截器(Interceptors)

    axios 的拦截器:interceptors 如果我们想在请求之前做点什么,用拦截器再好不过了 拦截器一般做什么? 1. 修改请求头的一些配置项 2. 给请求的过程添加一些请求的图标 3. 给请求添 ...

  7. Java操作符——i++ 和 ++i的区别

    问题:前置自增和后置自增的区别 Code-后置自增 public class Test { public static void main(String[] args) { int a = 2; in ...

  8. meta的相关属性

    <!DOCTYPE html> H5标准声明,使用 HTML5 doctype,不区分大小写<head lang=”en”> 标准的 lang 属性写法<meta cha ...

  9. append和push和pop区别

    append()    操作的是DOM节点,在被选元素的结尾(内部结尾)插入指定内容: push()        向数组末尾插入一个或者多个元素,并且返回新的长度: pop()         删除 ...

  10. LC 759. Employee Free Time 【lock, hard】

    We are given a list schedule of employees, which represents the working time for each employee. Each ...