JS实现小球的弹性碰撞效果


Posted in Javascript onNovember 11, 2017

一、HTML代码(body部分)

<body>
   <!--只需要做一个大div包裹几个小div即可,你想要几个小球碰撞就在内部做几个div即可,这里我们做了6个小球-->
   <div id="main">
     <div></div>
     <div></div>
     <div></div>
     <div></div>
     <div></div>
     <div></div>
   </div> 
 </body>

上面body部分这样就算是完成了,下面我们给body中的div做一些小样式。

二、CSS小球样式部分

<style type="text/css">
   /*将body默认的margin和padding部分去掉*/
   *{
     margin: 0px;
     padding: 0px;
    }
    /*采用定位的方式,让小球运动起来*/
    #main{
      margin: 0px auto;
     position: relative;
   }
   /*小球的样式*/
   #main div{
     overflow: hidden;
     position: absolute;
     width: 80px;
     height: 80px;
    opacity: 0.5;
     border-radius: 50%;
     background-color: red;
   }
 </style>

 

小球是要运动起来的,我们通过给小球和它的父元素添加定位,最后用js改变其top、bottom、left、right值来让小球运动。现在我们小球的样式已经做好了,下面的js代码才是重中之重。

3.1 Android 事件基础知识

其实,我们通过上面的代码就可以完全实现一个小球碰撞检测的功能了。但是仅仅是上面的代码,还是会存在一定的bug,就是当整个网站存在右侧滚动条时,当小球碰到屏幕右侧的时候,会出现一瞬的横向滚动条,这就是做网站比较忌讳的了,横向滚动条的出现太丑了。所以我们可以通过以下代码来解决。

//滚动条宽度计算函数
    function getScrollbarWidth() {
      var oP = document.createElement("p"),
        styles = {
          width: "100px",
          height: "100px",
          overflowY: "scroll"
        }, i, scrollbarWidth;
      for (i in styles) oP.style[i] = styles[i];
      document.body.appendChild(oP);
      scrollbarWidth = oP.offsetWidth - oP.clientWidth;
      oP.remove();
      return scrollbarWidth;
    }

以上是一个计算滚动条宽度的函数,此函数可以计算右侧滚动条的宽度,我们只需要在“根据浏览器窗口的大小自动调节小球的运动空间”上面,调用此函数

var scrollbarWidth = getScrollbarWidth(); 再修改小球的最大运动宽度   maxW=window.innerWidth-circles[0].clientWidth-scrollbarWidth ;这样这个bug就修改好了。

总结

以上所述是小编给大家介绍的JS实现小球的弹性碰撞效果 ,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
深入理解Javascript中的循环优化
Nov 09 Javascript
JavaScript/Js脚本处理html元素的自定义属性解析(亲测兼容Firefox与IE)
Nov 25 Javascript
JS获取及设置TextArea或input文本框选择文本位置的方法
Mar 24 Javascript
javascript中不易分清的slice,splice和split三个函数
Mar 29 Javascript
JavaScript重定向URL参数的两种方法小结
Oct 19 Javascript
AngularJS extend用法详解及实例代码
Nov 15 Javascript
vue.js之vue-cli脚手架的搭建详解
May 05 Javascript
angular-tree-component的使用详解
Jul 30 Javascript
JS获取当前时间的实例代码(昨天、今天、明天)
Nov 13 Javascript
layui表格数据重载
Jul 27 Javascript
vue项目打包为APP,静态资源正常显示,但API请求不到数据的操作
Sep 12 Javascript
vue swipeCell滑动单元格(仿微信)的实现示例
Sep 14 Javascript
jQuery实现checkbox即点即改批量删除及中间遇到的坑
Nov 11 #jQuery
解决vue组件中使用v-for出现告警问题及v for指令介绍
Nov 11 #Javascript
JS Input里添加小图标的两种方法
Nov 11 #Javascript
fetch 使用及如何接收JS传值
Nov 11 #Javascript
AngularJS使用ng-repeat遍历二维数组元素的方法详解
Nov 11 #Javascript
AngularJS遍历获取数组元素的方法示例
Nov 11 #Javascript
vue jsx 使用指南及vue.js 使用jsx语法的方法
Nov 11 #Javascript
You might like
PHP中的str_repeat函数在JavaScript中的实现
2013/09/16 PHP
Zend Framework页面缓存实例
2014/06/25 PHP
PHP 导出Excel示例分享
2014/08/18 PHP
PHP链接MySQL的常用扩展函数
2014/10/23 PHP
CI框架验证码CAPTCHA辅助函数用法实例
2014/11/05 PHP
PHP Static延迟静态绑定用法分析
2016/03/16 PHP
PHP面向对象类型约束用法分析
2019/06/12 PHP
php+mysql实现的无限分类方法类定义与使用示例
2020/05/27 PHP
jQuery Ajax 全解析
2009/02/08 Javascript
jQuery 相关控件的事件操作分解
2009/08/03 Javascript
javascript下对于事件、事件流、事件触发的顺序随便说说
2010/07/17 Javascript
使用jQuery fancybox插件打造一个实用的数据传输模态弹出窗体
2013/01/15 Javascript
jquery阻止冒泡事件使用模拟事件
2013/09/06 Javascript
屏蔽相应键盘按钮操作
2014/03/10 Javascript
js 加密压缩出现bug解决方案
2014/11/25 Javascript
JS操作HTML自定义属性的方法
2015/02/10 Javascript
jQuery控制网页打印指定区域的方法
2015/04/07 Javascript
jquery.validate使用时遇到的问题
2015/05/25 Javascript
JavaScript预解析及相关技巧分析
2016/04/21 Javascript
JavaScript和jquery获取父级元素、子级元素、兄弟元素的方法
2016/06/05 Javascript
最棒的Angular2表格控件
2016/08/10 Javascript
浅谈jquery的html方法里包含特殊字符的处理
2016/11/30 Javascript
微信小程序之onLaunch与onload异步问题详解
2019/03/28 Javascript
详解在Angular4中使用ng2-baidu-map的方法
2019/06/19 Javascript
js实现简单五子棋游戏
2020/05/28 Javascript
[02:57]DOTA2亚洲邀请赛 SECRET战队出场宣传片
2015/02/07 DOTA
Python中的字符串替换操作示例
2016/06/27 Python
python批量修改文件编码格式的方法
2018/05/31 Python
高中数学教师求职信
2013/10/30 职场文书
军训教官感言
2014/03/02 职场文书
大学生求职计划书
2014/04/30 职场文书
德育标兵事迹材料
2014/08/24 职场文书
分居协议书范本
2014/11/03 职场文书
小学六一儿童节活动总结
2015/05/05 职场文书
2015年大学辅导员工作总结
2015/05/12 职场文书
春节晚会开场白
2015/05/29 职场文书