• 用js做一个方块 在网页窗口运动 遇到边角反弹


    //css代码

    <style>
      div{
      100px;
      height: 100px;
      background-color: brown;
      position: absolute;
      }
      </style>
      </head>
      <body>
      <button>移动</button>
      <div style="top: 30px;left:8px"></div>
      <script>
      let btn = document.getElementsByTagName("button")[0];//获取按钮
      let div = document.getElementsByTagName("div")[0];//获取移动的div
      let switchDirX = 'on', switchDirY = 'on';//设置两个标识来跟踪x,y轴的运动情况
      let move = function(){
      let divLeft = parseInt(div.style.left);//将获取到的left值取整。去除后面的px单位
      let divTop = parseInt(div.style.top);//将获取到的top值取整,去除后面的px单位
      //x轴运动
      if(divLeft<innerWidth - 100 && switchDirX === 'on'){
      div.style.left = divLeft + 1 + "px";
      }
      else if(divLeft === innerWidth - 100 || switchDirX === 'off'){
      switchDirX = 'off';
      div.style.left = divLeft - 1 + "px";
      if(divLeft === 0){
      switchDirX = 'on';
      }
      }
      //y轴运动
      if(divTop<innerHeight - 100 && switchDirY === 'on'){
      div.style.top = divTop + 1 + "px";
      }
      else if(divTop === innerHeight - 100 || switchDirY === 'off'){
      switchDirY = 'off';
      div.style.top = divTop - 1 + "px";
      if(divTop === 0){
      switchDirY = 'on'
      }
      }
      }
      btn.onclick = function(){
      if (btn.innerHTML === "移动"){
      btn.innerHTML = "暂停";
      stopTimer = setInterval(move,0.00000000001);
      }
      else{
      btn.innerHTML = "移动";
      clearInterval(stopTimer);
      }
      }
      </script>
  • 相关阅读:
    彻底弄懂类设计原则之 单一职责原则
    CF1592F1 Alice and Recoloring 1
    CF1592E Bored Bakry
    AT1218 たのしい家庭菜園
    CF1479A Searching Local Minimum
    P3295 [SCOI2016]萌萌哒
    CF1572B Xor of 3
    项目开发和管理需要弄清楚的6个问题
    PowerDesigner中如何生成主键和自增列Oracle版本
    js获取下拉框的选中值和文本值,后台获取用Request["XXXX"]即可
  • 原文地址:https://www.cnblogs.com/gao2/p/11427629.html
Copyright © 2020-2023  润新知