菜单

JS达成小球的弹性碰撞效果

2019年6月6日 - 皇家前端

一、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.一 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;
    }

以上是1个计量滚动条宽度的函数,此函数能够计算左侧滚动条的急剧,我们只须求在“依据浏览器窗口的轻重活动调解小球的运动空间”上边,调用此函数

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

总结

如上所述是作者给大家介绍的JS完成小球的弹性碰撞效果
,希望对我们全部协理,假如大家有其余疑问招待给作者留言,作者会及时还原大家的!

你大概感兴趣的稿子:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图