zoukankan      html  css  js  c++  java
  • 百度前端学院task33源码及总结——听指令的小方块

    任务描述

    • 如图,实现一个类似棋盘的格子空间,每个格子用两个数字可以定位,一个红正方形的DOM在这个空间内,正方形中的蓝色边表示这是他的正面,有一个input输入框
    • 在输入框中允许输入如下指令,按下按钮后,使得正方形做相应动作
      • GO:向蓝色边所面向的方向前进一格(一格等同于正方形的边长)
      • TUN LEF:向左转(逆时针旋转90度)
      • TUN RIG:向右转(顺时针旋转90度)
      • TUN BAC:向右转(旋转180度)
    • 移动不能超出格子空间

    分析:(结合源码来看)

      1、首先我们得画一张棋盘,棋盘可以采用表格的形式,也可以采用其他形式,看个人喜好。

      2、首先我们采用draw函数将小方块显示在某个位置。

      3、后面其实就是命令的处理,我们分为两部分,一个是旋转函数,一个是移动函数。根据相应的命令,执行相应的代码就好。

      注意点:减少全局变量的使用;

          尽量减少代码的重复;

          采用事件委托的形式,只需要写一个绑定事件就可以了,根据target.id来判断是按了哪一个按钮。

    中间遇到的问题:

      1、编程过程中,再旋转之后,当再用go的命令,旋转的效果就会失效。

    原因:分两次设置css样式,且旋转需要在位置改变之前;

    体验网址:http://1.huanssky.applinzi.com/ablum/ife/task33.html。

    源代码:

    <!doctype html>
    <html>
      <head>
        <title>听指令的小方块  by huansky</title>
        <meta charset="utf-8"/>
        <style type="text/css">
        h1 {
          font:400 16px/1 "Microsoft YaHei",KaiTi_GB2312,SimSun;
          text-align: center;
        }
        #main{
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translateY(-50%) translateX(-50%); 
    
        }
        #container{
          position: relative;
          border: 1px solid #ddd;
          width: 500px;
          height: 500px;
        }
        span{
          width: 50px;
          height: 50px;
          border: 1px solid #ddd;
          float: left;
          -moz-box-sizing: border-box;  /*Firefox3.5+*/
          -webkit-box-sizing: border-box; /*Safari3.2+*/
          -o-box-sizing: border-box; /*Opera9.6*/
          -ms-box-sizing: border-box; /*IE8*/
          box-sizing: border-box; /*W3C标准(IE9+,Safari5.1+,Chrome10.0+,Opera10.6+都符合box-sizing的w3c标准语法)*/
        }
        #box{
          position: absolute;
          width: 50px;
          height: 50px;
          -moz-box-sizing: border-box;  /*Firefox3.5+*/
          -webkit-box-sizing: border-box; /*Safari3.2+*/
          -o-box-sizing: border-box; /*Opera9.6*/
          -ms-box-sizing: border-box; /*IE8*/
          box-sizing: border-box; /*W3C标准(IE9+,Safari5.1+,Chrome10.0+,Opera10.6+都符合box-sizing的w3c标准语法)*/ 
        }
        #box .up{
          background: blue;
          height: 10px;
          width: 100%;
          position: relative;
          border: none;
        }
        #box .down{
          background: red;
          height: 40px;
          width: 100%;
          position: relative;
          border: none;
        }
        p{
          color: red;
          text-align: center;
        }
        input{
          margin: 6px;
        }
      </style>
    </head>
    <body>
      <div id="main">
        <h1>听指令的小方块 by huansky</h1>
        <p id="message"></p>
        <div id="container">
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span>
          <div id="box"><span class="up"></span><span class="down"></span></div>
          <span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
          <span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span><span></span>
        </div>
        <br>
        <label><input type="text" id="invalue">请输入命令:go, left, right, back; 不区分大小写</label>
        <div id="btndir"><input type="button" id="excute" value="执行">
          <input id="go" type="button" value="GO">
          <input id="tunLef" type="button" value="LEFT">
          <input id="tunRig" type="button" value="RIGHT">
          <input id="tunBac" type="button" value="BACK">
        </div>
      </div>
    </body>
    <script type="text/javascript">
        
        //将所有的变量都放在moveBox里面。
        var moveBox={
            box:getid("box") ,  //获取小块的id
            invalue:getid("invalue") ,  //输入框的id
            btndir:getid("btndir"),     //获取按钮容器的id
            left:100,     //左边距          
            topl:100,     //上边距
            direction:1,  //(0代表左,1代表up,2代表右,3代表down)
            current:0,    //当前角度
            message:getid("message")    //获取信息id
        }
    
        //获取id方法
        function getid(id){
          return document.getElementById(id);
        }
    
        //根据指令进行相应的旋转
        function rotate(dir){
    
            switch(dir){
              case "left":
                moveBox.current = (moveBox.current-90)%360;  //计算当前需要转的角度
                draw();
                moveBox.direction--;  //改变方向
                break;
    
              case "right":
                moveBox.current = (moveBox.current+90)%360;  //计算当前需要转的角度
                draw();
                moveBox.direction++;  //改变方向
                break;
    
              case "back":
              moveBox.current = (moveBox.current+180)%360;  //计算当前需要转的角度
                draw();
                moveBox.direction++;
                moveBox.direction++;  //改变方向
                break;
              case "go":
                go();
                break;
            }
      }
    
    
        function go(){
            //修正方向,使其在[0,4)之间
            moveBox.direction=moveBox.direction % 4+(moveBox.direction % 4 < 0 ? 4 : 0);
              
            if(moveBox.direction==0 && moveBox.left>0){
              moveBox.left=moveBox.left-50;
              draw();
            }else if(moveBox.direction==1 && moveBox.topl>0 ){
              moveBox.topl=moveBox.topl-50;
              draw();
            }else if(moveBox.direction==2 && moveBox.left<450){
              moveBox.left=moveBox.left+50;
              draw();
            }else if(moveBox.direction==3 && moveBox.topl<450){
              moveBox.topl=moveBox.topl+50;
              draw();
            } else {
              //当超出界限的时候,弹出提醒信息
              moveBox.message.innerHTML="移动不能超出格子空间";
            }
        }
    
        //事件绑定函数
        function on(element,eventName,listener){
    
            if (element.addEventListener){
                element.addEventListener(eventName,listener,false);
            }
            else if (element.attachEvent){
                element.attachEvent('on'+eventName,listener);
            }
            else
                element['on'+eventName]=listener;
        }
    
        //进行事件绑定
        on(btndir,"click",function(dir){
    
            var e=window.event||event;
            var target=e.target  || e.srcElement;
            dir=target.id
            switch(target.id){
              case "tunLef":
                rotate("left");
                break;
              case "tunRig":
                rotate("right");
                break;
              case "tunBac":
                rotate("back");
                break;
              case "go":
                go();
                break;
              case "excute":
                var dir=moveBox.invalue.value.toLowerCase();
                rotate(dir);
                break;
            }
        });
        
        //重绘小块的样式
        function draw(){
          moveBox.box.style.cssText='transform:rotate('+ (moveBox.current) +'deg);';
          moveBox.box.style.left=moveBox.left+"px";
          moveBox.box.style.top=moveBox.topl+"px";
          moveBox.message.innerHTML="";
        }
    
        draw(); //显示
      
    </script>
    </html>
    View Code
  • 相关阅读:
    设计模式之责任链模式(Chain of Responsibility )
    Cubieboard2裸机开发之(二)板载LED交替闪烁
    Cubieboard2裸机开发之(一)点亮板载LED
    A20(Cubieboard2)启动过程浅析
    入手Cubieboard2之制作最小Linux系统
    ARM Linux启动代码分析
    Linux设备驱动剖析之Input(四)
    Linux设备驱动剖析之Input(三)
    Linux设备驱动剖析之Input(二)
    Linux设备驱动剖析之Input(一)
  • 原文地址:https://www.cnblogs.com/huansky/p/5492389.html
Copyright © 2011-2022 走看看