JavaScript实现多球运动效果


Posted in Javascript onSeptember 07, 2020

本文实例为大家分享了JavaScript实现多球运动的具体代码,供大家参考,具体内容如下

JavaScript实现多球运动效果

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>多球运动</title>
  <style>
    *{margin:0;padding:0;}
    body{background-color: #90f;}
    .ball{position: absolute;left:0;top:0;width:100px;height:100px;background: #f0f;border-radius: 50%;}
  </style>
</head>
<body>
  <script>
    run(22)//封装
    //定义速度
    var speed;
    function run(num){
      //创建出num个div
      for(var i=0;i<num;i++){
        //[2,11) 随机速度
        speed = Math.floor(Math.random()*9+2);
        //创建生成节点
        var div = document.createElement("div");
        //添加类名
        div.className = 'ball'
        //自定义属性保存值
        div.speedX = Math.floor(Math.random()*9+2)
        div.speedY = Math.floor(Math.random()*9+2)
        //将div放置到body中
        document.body.appendChild(div)
      }
      //获取元素
      var box = document.getElementsByClassName( "ball" )
      //获取文档可视区域的宽高
      var maxX = document.documentElement.clientWidth - box[0].offsetWidth;
      var maxY = document.documentElement.clientHeight - box[0].offsetHeight;
      //自适应窗口
      window.onresize = function(){
        maxX = document.documentElement.clientWidth - box[0].offsetWidth;
        maxY = document.documentElement.clientHeight - box[0].offsetHeight;
      }
      play()
      function play(){
        for(var i=0;i<num;i++){
          //获取
          var ball = box[i];
          var startTop = ball.offsetTop;
          var startLift = ball.offsetLeft;
          //startTop都为零;
          var top = startTop + ball.speedY;
          var left = startLift + ball.speedX;
          //判断小球是否出左右边界
          if(left <= 0 || left >= maxX){
            //改变方向
            ball.speedX = -ball.speedX;
            ball.style.background=randomColor()
            //判断
            if(left <= 0){
              left = 0;
            }else if(left >= maxX){
              left = maxX;
            }
          }
          //判断小球是否出上下边界
          if(top <= 0 || top >= maxY ){
            // 改变方向;
            ball.speedY = -ball.speedY; 
            ball.style.background=randomColor()
            //判断
            if( top <= 0 ){
              top = 0;
            }else if( top >= maxY ){
              top = maxY;
            }
          }
          ball.style.top = top + "px";
          ball.style.left = left + "px";          
        }
        //执行动画帧
        requestAnimationFrame(play);
      }
      //颜色随机
      function randomColor() {
        var r = Math.floor(Math.random() * 256),
          g = Math.floor(Math.random() * 256),
          b = Math.floor(Math.random() * 256);
          return "rgb(" + r + "," + g + "," + b + ")";
      }
    }
  </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用JavaScript事件串连执行多个处理过程的方法
Mar 09 Javascript
JQuery 获取json数据$.getJSON方法的实例代码
Aug 02 Javascript
一个支付页面DEMO附截图
Jul 22 Javascript
jQuery实现跟随鼠标运动图层效果的方法
Feb 02 Javascript
JavaScript中的this关键字使用方法总结
Mar 13 Javascript
win7下安装配置node.js+express开发环境
Dec 06 Javascript
全面理解JavaScript中的继承(必看)
Jun 16 Javascript
Javascript之面向对象--封装
Dec 02 Javascript
vue-router命名视图的使用讲解
Jan 19 Javascript
如何从零开始手写Koa2框架
Mar 22 Javascript
vue实现简单瀑布流布局
May 28 Javascript
用JS实现选项卡
Mar 23 Javascript
JavaScript实现世界各地时间显示
Sep 07 #Javascript
VUE UPLOAD 通过ACTION返回上传结果操作
Sep 07 #Javascript
vue中element 的upload组件发送请求给后端操作
Sep 07 #Javascript
vue-simple-uploader上传成功之后的response获取代码
Sep 07 #Javascript
Vue.js暴露方法给WebView的使用操作
Sep 07 #Javascript
三步搞定:Vue.js调用Android原生操作
Sep 07 #Javascript
vue单应用在ios系统中实现微信分享功能操作
Sep 07 #Javascript
You might like
PHP中让curl支持sock5的代码实例
2015/01/21 PHP
laravel 5 实现模板主题功能
2015/03/02 PHP
php写入数据到CSV文件的方法
2015/03/14 PHP
php实现mysql数据库分表分段备份
2015/06/18 PHP
PHP解耦的三重境界(浅谈服务容器)
2017/03/13 PHP
PHP rmdir()函数的用法总结
2019/07/02 PHP
laravel 框架执行流程与原理简单分析
2020/02/01 PHP
XML的代替者----JSON
2007/07/21 Javascript
jquery tab插件制作实现代码
2010/06/22 Javascript
JavaScript 反科里化 this [译]
2012/09/20 Javascript
jquery限定文本框只能输入数字即整数和小数
2013/11/29 Javascript
jQuery中wrapInner()方法用法实例
2015/01/16 Javascript
jQuery对象的链式操作用法分析
2016/05/10 Javascript
jQuery 特性操作详解及实例代码
2016/09/29 Javascript
jQuery实现ToolTip元素定位显示功能示例
2016/11/23 Javascript
vue 中自定义指令改变data中的值
2017/06/02 Javascript
vue倒计时刷新页面不会从头开始的解决方法
2020/03/03 Javascript
浅析vue中的nextTick
2020/12/28 Vue.js
使用Nginx+uWsgi实现Python的Django框架站点动静分离
2016/03/21 Python
python实现微信远程控制电脑
2018/02/22 Python
Python3.5集合及其常见运算实例详解
2019/05/01 Python
java判断三位数的实例讲解
2019/06/10 Python
一文秒懂python读写csv xml json文件各种骚操作
2019/07/04 Python
Python实现密钥密码(加解密)实例详解
2020/04/26 Python
什么是python的列表推导式
2020/05/26 Python
基于python获取本地时间并转换时间戳和日期格式
2020/10/27 Python
HTML5 CSS3给网站设计带来出色效果
2009/07/16 HTML / CSS
Timex手表官网:美国运动休闲手表品牌
2017/01/28 全球购物
台湾线上百货零售购物平台:friDay购物
2017/08/18 全球购物
装修设计师求职信
2014/02/26 职场文书
端午节演讲稿
2014/05/23 职场文书
企业法人代表任命书
2014/06/06 职场文书
开票证明
2015/06/23 职场文书
全民创业工作总结
2015/08/13 职场文书
2016年幼儿园教研活动总结
2016/04/05 职场文书
mysql通过group by分组取最大时间对应数据的两种有效方法
2022/09/23 MySQL