育新吧 关注:1,497贴子:175,947
  • 8回复贴,共1

哪位大哥帮我瞧瞧以下这段代码错在哪了~~~感激不尽

只看楼主收藏回复

<html>
<head>
<title>Sweep Mine Text-Edition v1.5 gama</title>
<meta http-equiv="Content-Type" content="text/html;">
<meta http-equiv="pragma" content="no-cache">
<style type=text/css>
body{font-size:11px;font-family: verdana;background-color:white}
#work td{
cursor:hand;
width:14px;
height:14px;
text-align: center;
font-family: verdana;
font-size:12;
font-weight: 652;
}
#demo td{
cursor:hand;
width:14px;
height:14px;
text-align: center;
font-family: verdana;
font-size:12;
}
#radio td{font-size:11px;}
#work{border:6 solid #646AA6;}
#tbs{width:10;height:10;cursor:hand;font-size:5px;}
button{font-family:verdana;font-size:11px;border:0;};
input{font-family:verdana;font-size:11px;border:0;};
a{cursor:hand;background-color:#ffffff;}
</style>

<!-- game design -->
<script language="JavaScript" type="text/javascript">
<!--
var str=''
var succ=0
var gameup=0
var gtime=0

function ini(){
gameup=0
succ=0
gtime=0
gintervalid=setInterval("tickTime()",1000);
str='<table id=work cellspacing=0 cellpadding=0 border=0 bgcolor=#DDDDDD onmousedown=click1()>' 
for(var i=0;i<row.value;i++){
str+='<tr>'
for(var j=0;j<cell.value;j++)
str+='<td></td>'
str+='</tr>'
}
str+='</table>'
main.innerHTML=str
rand();
}

function tickTime()
{
showStatus();
gtime++;
}

function showStatus(){
var x,y,z
x=Math.floor(gtime%1000/100)
y=Math.floor(gtime%100/10)
z=gtime%10
jsq.innerText=100*x+10*y+z+' seconds'
}

function rand(){
var t=new Array(200)
var k=0
var f=0
for(var i=0;i<row.value;i++)
for(var j=0;j<cell.value;j++){
obj(i,j).fl=0
obj(i,j).flag=0
obj(i,j).a1=i
obj(i,j).b1=j
obj(i,j).isclicked=0
obj(i,j).rc=0//right click times
obj(i,j).innerText=' '
obj(i,j).style.borderLeft='1 solid '+k1.value
obj(i,j).style.borderTop='1 solid '+k2.value
obj(i,j).style.borderRight='1 solid '+k3.value
obj(i,j).style.borderBottom='1 solid '+k4.value
obj(i,j).style.backgroundColor=k5.value
}
for(i=0;i<Math.floor(row.value*cell.value/8);i++){
while(1){
f=0
var a=Math.floor(Math.random()*row.value*cell.value)+1
for(var j=0;t[j];j++)
if(a==t[j]){f=1;}
if(f)continue;
t[k++]=a
t[k]=0
x1=Math.floor((a-1)/cell.value)
y1=Math.floor((a-1)%cell.value)
work.rows(x1).cells(y1).flag=1
break;
}
}
for(var i=0;i<row.value;i++)
for(var j=0;j<cell.value;j++){
if(obj(i,j).flag==0)
shownum(i,j);
}
}

function click1(){
if(gameup==1)return false
var cl=event.srcElement;
if(event.button==1&&!cl.rc){
if(cl.flag){//is a mine
gameup=1
clearInterval(gintervalid);

for(var i=0;i<row.value;i++)
for(var j=0;j<cell.value;j++)
if(obj(i,j).flag==1){
obj(i,j).style.color='black'
obj(i,j).innerText='M'
obj(i,j).style.borderLeft='1 solid '+k6.value
obj(i,j).style.borderTop='1 solid '+k7.value
obj(i,j).style.borderRight='1 solid '+k8.value
obj(i,j).style.borderBottom='1 solid '+k9.value
obj(i,j).style.backgroundColor=k0.value
}
cl.style.color='red'
}else{
if(cl._value&&!cl.isclicked){
cl.style.borderLeft='1 solid '+k6.value
cl.style.borderTop='1 solid '+k7.value
cl.style.borderRight='1 solid '+k8.value



1楼2005-04-29 22:25回复
    cl.style.borderBottom='1 solid '+k9.value
    cl.style.backgroundColor=k0.value
    shownum(cl.a1,cl.b1)
    cl.innerText=cl._value
    cl.isclicked=1
    succ++
    }else{
    if(!cl.isclicked){
    deal0(cl.a1,cl.b1) 
    }
    else return 
    }
    if(succ==(row.value*cell.value-Math.floor(row.value*cell.value/8))){
    alert('Congratulations!')
    gameup=1
    clearInterval(gintervalid);

    }
    }
    }else if(event.button==2&&!cl.isclicked){
    if(cl.rc==0){
    cl.rc++
    cl.style.color='red'
    document.oncontextmenu=new Function("event.returnValue=false;");
    cl.innerText='m'
    }
    else if(cl.rc==1){
    cl.rc++
    cl.style.color='red'
    document.oncontextmenu=new Function("event.returnValue=false;"); 
    cl.innerText='?'
    }
    else if(cl.rc==2){
    cl.rc=0
    document.oncontextmenu=new Function("event.returnValue=false;"); 
    cl.innerHTML=' '
    }
    }
    }

    function deal0(i,j){
    succ++

    if(!obj(i,j).rc){
    obj(i,j).isclicked=1
    obj(i,j).style.borderLeft='1 solid '+k6.value
    obj(i,j).style.borderTop='1 solid '+k7.value
    obj(i,j).style.borderRight='1 solid '+k8.value
    obj(i,j).style.borderBottom='1 solid '+k9.value
    obj(i,j).style.backgroundColor=k0.value
    }
    obj(i,j).fl=1;
    if(i&&!obj(i-1,j).fl&&!obj(i-1,j)._value)deal0(i-1,j);//up
    if(j<(cell.value-1)&&!obj(i,j+1).fl&&!obj(i,j+1)._value)deal0(i,j+1);//right
    if(i<(row.value-1)&&!obj(i+1,j).fl&&!obj(i+1,j)._value)deal0(i+1,j);//down
    if(j&&!obj(i,j-1).fl&&!obj(i,j-1)._value)deal0(i,j-1);//left
    if(i&&j&&!obj(i-1,j-1).fl&&!obj(i-1,j-1)._value)deal0(i-1,j-1);
    if(i&&j<cell.value-1&&!obj(i-1,j+1).fl&&!obj(i-1,j+1)._value)deal0(i-1,j+1);
    if(i<row.value-1&&j<row.value-1&&!obj(i+1,j+1).fl&&!obj(i+1,j+1)._value)deal0(i+1,j+1);
    if(i<row.value-1&&j&&!obj(i+1,j-1).fl&&!obj(i+1,j-1)._value)deal0(i+1,j-1);

    for(var n=1;n<=8;n++)
    eval('border0(i,j,'+n+')')
    }

    function obj(i,j){
    return work.rows(i).cells(j)
    }

    function border0(i,j,k){//k 1-8 
    var m,n,f=0
    switch(k){
    case 1:m=i-1;n=j;if(i&&obj(m,n)._value)f=1;break;//up
    case 2:m=i;n=j+1;if(j<cell.value-1&&obj(m,n)._value)f=1;break;//right
    case 3:m=i+1;n=j;if(i<row.value-1&&obj(m,n)._value)f=1;break;//down
    case 4:m=i;n=j-1;if(j&&obj(m,n)._value)f=1;break;//left
    case 5:m=i-1;n=j-1;if(i&&j&&obj(m,n)._value)f=1;break;//left-up
    case 6:m=i-1;n=j+1;if(i&&j<cell.value-1&&obj(m,n)._value)f=1;break;//right-up
    case 7:m=i+1;n=j+1;if(i<row.value-1&&j<cell.value-1&&obj(m,n)._value)f=1;break;//right-down
    case 8:m=i+1;n=j-1;if(i<row.value-1&&j&&obj(m,n)._value)f=1;break;//left-down
    default:break;
    }
    if(f==1&&!obj(m,n).rc){
    obj(m,n).style.borderLeft='1 solid '+k6.value
    obj(m,n).style.borderTop='1 solid '+k7.value
    obj(m,n).style.borderRight='1 solid '+k8.value
    obj(m,n).style.borderBottom='1 solid '+k9.value
    obj(m,n).style.backgroundColor=k0.value
    obj(m,n).innerText=obj(m,n)._value
    if(!obj(m,n).isclicked){
    succ++
    obj(m,n).isclicked=1
    }
    }
    }

    function shownum(i,j){//0=<i<=level.value-1
    var c=0;
    if(i<(row.value-1)&&obj(i+1,j).flag==1)c++;//down
    if(i>0&&obj(i-1,j).flag==1)c++;//up
    if(j<(cell.value-1)&&obj(i,j+1).flag==1)c++;//right
    if(j>0&&obj(i,j-1).flag==1)c++;//left
    if(i>0&&j>0&&work.rows(i-1).cells(j-1).flag==1)c++
    


    2楼2005-04-29 22:25
    回复
      if(i>0&&j<cell.value-1&&work.rows(i-1).cells(j+1).flag==1)c++
      if(i<row.value-1&&j>0&&work.rows(i+1).cells(j-1).flag==1)c++
      if(i<row.value-1&&j<cell.value-1&&work.rows(i+1).cells(j+1).flag==1)c++
      obj(i,j)._value=c
      switch?{
      case 1:obj(i,j).style.color='blue';break
      case 2:obj(i,j).style.color='green';break
      case 3:obj(i,j).style.color='red';break
      case 4:obj(i,j).style.color='black';break
      }
      }
      //-->
      </script>

      <!-- color design -->
      <script language="javascript">
      <!--
      var hex = new Array(8)
      var he=new Array(16)
      var f1=0,f2=0,f3=0
      var s1='<table cellpadding=0 cellspacing=0 border=0><tr>'
      var s2=''
      var s3=''
      var s4=''
      var fc=0
      var s5='choose the direction of light  [<a onclick="selectfirst(1);fc=1;">left-top</a>]   [<a  onclick="selectfirst(2);fc=2;">right-top]'
      var p=3

      for(var i=0;i<50;i++)
      s1+='<td id=tbs onclick=getcolor(fc)> </td>'
      s1+='</tr><tr>'
      for(var i=0;i<50;i++)
      s1+='<td id=tbs onclick=getcolor(fc)> </td>'
      s1+='</tr></table>'
      var hexChars = "0123456789ABCDEF";

      s3='<table border=0 cellpadding=0 cellspacing=0 id=demo style="margin-left:5;">'
      for(var i=0;i<3;i++){
      s3+='<tr>'
      for(var j=0;j<3;j++)
      s3+='<td> </td>'
      s3+='</tr>'
      }
      s3+='</table>'

      hex[0] = "ee"
      hex[1] = "CC"
      hex[2] = "aa"
      hex[3] = "88"
      hex[4] = "66"
      hex[5] = "44"
      hex[6] = "22"
      hex[7] = "00"

      for(var i=15;i>=0;i--){
      if(i>5)he[i]=''+(15-i)+(15-i)
      else if(i==5)he[i]='aa'
      else if(i==4)he[i]='bb'
      else if(i==3)he[i]='cc'
      else if(i==2)he[i]='dd'
      else if(i==1)he[i]='ee'
      else if(i==0)he[i]='ff'
      }

      function getcolor(q){
      switch(q){
      case 1:
      if(c1){
      k2.value=event.srcElement.style.backgroundColor;d(2);
      k1.value=event.srcElement.style.backgroundColor;d(1);
      }
      if(c2){
      k3.value=event.srcElement.style.backgroundColor;d(3);
      k4.value=event.srcElement.style.backgroundColor;d(4);
      }
      if(c3){
      k5.value=event.srcElement.style.backgroundColor;d(5);
      k8.value=event.srcElement.style.backgroundColor;d(8);
      k9.value=event.srcElement.style.backgroundColor;d(9);
      }
      if(c4){k0.value=event.srcElement.style.backgroundColor;d(0);}
      break;
      case 2:
      if(c1){
      k2.value=event.srcElement.style.backgroundColor;d(2);
      k3.value=event.srcElement.style.backgroundColor;d(3);
      }
      if(c2){
      k1.value=event.srcElement.style.backgroundColor;d(1);
      k4.value=event.srcElement.style.backgroundColor;d(4);
      }
      if(c3){
      k5.value=event.srcElement.style.backgroundColor;d(5);
      k6.value=event.srcElement.style.backgroundColor;d(6);
      k9.value=event.srcElement.style.backgroundColor;d(9);
      }
      if(c4){k0.value=event.srcElement.style.backgroundColor;d(0);}
      break;
      default:break;
      }
      }

      function todec(i){
      if(i.substr(0,1)=='a')return 170
      else if(i.substr(0,1)=='b')return 187
      else if(i.substr(0,1)=='c')return 204
      else if(i.substr(0,1)=='d')return 221
      else if(i.substr(0,1)=='e')return 238
      else if(i.substr(0,1)=='f')return 255
      else return i*1
      }

      function ch(i){
      if(i==15)return 'f'
      else if(i==14)return 'e'
      else if(i==13)return 'd'
      else if(i==12)return 'c'
      else if(i==11)return 'b'
      else return 'a'
      }

      function tohex (Dec) 
      {
      var a=Dec%16;
      


      3楼2005-04-29 22:25
      回复
        var b=(Dec-a)/16;
        hexx=""+hexChars.charAt(b)+hexChars.charAt(a);
        return hexx;
        }

        function clearcolor(){
        for(var i=0;i<50;i++)
        document.all.tbs[i].style.backgroundColor='white'
        }

        function display(triplet){
        var k1=0,k2=0,k3=0
        clearcolor()
        for(var i=0;i<16;i++){
        if(triplet.substr(0,2)==he[i])k1=i
        if(triplet.substr(2,2)==he[i])k2=i
        if(triplet.substr(4,2)==he[i])k3=i
        }
        for(var j=0;j<50;j++)
        document.all.tbs[j].style.backgroundColor='#'+tohex(255-j*(255-todec(he[k1]))/50)+tohex(255-j*(255-todec(he[k2]))/50)+tohex(255-j*(255-todec(he[k3]))/50)
        for(var j=50;j<100;j++)
        document.all.tbs[j].style.backgroundColor='#'+tohex(todec(he[k1])-(j-50)*(todec(he[k1]))/50)+tohex(todec(he[k2])-(j-50)*(todec(he[k2]))/50)+tohex(todec(he[k3])-(j-50)*(todec(he[k3]))/50)
        }

        function colortable(){
        s2='<table cellpadding=0 cellspacing=0 border=0 width=80 height=80 align=left >'
        for (var i=0;i<8;i++){
        s2+='<tr>'
        for(var j=0;j<8;j++){
        s2+='<td bgcolor=#'+hex[p]+hex[i]+hex[j]+' style="font-size:1;cursor:hand;" onclick=display(\"'+hex[p]+hex[i]+hex[j]+'\")>'
        s2+=' '
        s2+='</td>'
        }
        s2+='</tr>'
        }
        s2+='</table>'
        return s2+'Click the color you like,then 2 anti direction color band of this color will be shown just below,select diffent radio button,and select the color in one of the 2 bands,then the according effection will be shown by the demo-table,<em>enjoy!</em> by <strong>Alex</strong>'
        }

        function drawTable(){
        w2.innerHTML='<table id=aaa cellpadding=2 cellspacing=0 style="border-top:2 solid #7E84B8;font-size:10px;"><tr><td width=50%>'+colortable()+'</td><td align=left valign=top style="border-left:1 dotted #EAEEF4"><strong>color style demo</strong><br>'+s3+'<a style="position:absolute;top:95;">If you like this style,click <u>Apply</u> above.</a></td></tr><tr><td colspan=2 style="border-top:1 dotted #EAEEF4">'+s1+'</td></tr></table>'
        w3.innerHTML=s5
        }

        function ct1(){
        if(p){
        p--;
        aaa.rows(0).cells(0).innerHTML=colortable()
        }else return false
        }

        function ct2(){
        if(p<7){
        p++;
        aaa.rows(0).cells(0).innerHTML=colortable()
        }
        else return false
        }

        var isfirst=1
        function sh(){
        if(w1.style.display=='none'){
        w1.style.display='block';
        b0.value='hide window';
        }else{
        w1.style.display='none';
        b0.value='Color Style Design';
        }
        if(isfirst){
        drawTable()
        isfirst=0
        }
        }

        function d(i){
        switch(i){
        case 0:demo.rows(1).cells(1).style.backgroundColor=k0.value;break
        case 9:demo.rows(1).cells(1).style.borderBottom=k9.value;break
        case 8:demo.rows(1).cells(1).style.borderRight=k8.value;break
        case 7:demo.rows(1).cells(1).style.borderTop=k7.value;break
        case 6:demo.rows(1).cells(1).style.borderLeft=k6.value;break
        case 5:for(var i=0;i<3;i++)
        for(var j=0;j<3;j++){
        demo.rows(i).cells(j).style.backgroundColor=k5.value
        }
        break;
        case 4:for(var i=0;i<3;i++)
        for(var j=0;j<3;j++){
        demo.rows(i).cells(j).style.borderBottom='1 solid '+k4.value
        }
        break;
        case 3:for(var i=0;i<3;i++)
        for(var j=0;j<3;j++){
        demo.rows(i).cells(j).style.borderRight='1 solid '+k3.value
        }
        break;
        case 2:for(var i=0;i<3;i++)
        


        4楼2005-04-29 22:25
        回复
          for(var j=0;j<3;j++){
          demo.rows(i).cells(j).style.borderTop='1 solid '+k2.value
          }
          break
          case 1:for(var i=0;i<3;i++)
          for(var j=0;j<3;j++){
          demo.rows(i).cells(j).style.borderLeft='1 solid '+k1.value
          }
          break
          default:break;
          }
          }

          var c1=0,c2=0,c3=0,c4=0
          function set1(j){
          for(var i=1;i<=4;i++){
          eval('c'+i+'=0')
          eval('q'+i+'.style.backgroundColor="#ffffff"')
          eval('q'+i+'.style.color="black"')
          }
          eval('c'+j+'=1')
          eval('q'+j+'.style.backgroundColor="#267DA8"')
          eval('q'+j+'.style.color="#FFFFFF"')
          }

          function selectfirst(i){
          switch(i){
          case 1:s4='<a id=q1 onclick="set1(1);">left-top</a>  <a id=q2 onclick="set1(2);">right-bottom</a>  <a id=q3 onclick="set1(3);">b-surface</a>  <a id=q4 onclick="set1(4);">f-surface</a>  <a onclick="w3.innerHTML=s5;fc=0;" style="background-color:#F0F4F0;cursor:hand;">RETURN</a>';w3.innerHTML=s4;break;
          case 2:s4='<a id=q1 onclick="set1(1);">right-top</a>  <a id=q2 onclick="set1(2);">left-bottom</a>  <a id=q3 onclick="set1(3);">b-surface</a>  <a id=q4 onclick="set1(4);">f-surface</a>  <a onclick="w3.innerHTML=s5;fc=0;" style="background-color:#F0F4F0;cursor:hand;">RETURN</a>';w3.innerHTML=s4;break;
          default:break;
          }
          }
          //-->
          </script>
          </head>

          <body onLoad=ini()>
          <div id=main></div><br><table id=radio>
          <tr>
          <td><button onclick=ini()>Play Again</button></td>
          <td>rows </td>
          <td><input name=row value=8 size=1  onmouseover="this.style.backgroundColor='#F0F0F0'" onmouseout="this.style.backgroundColor='#ffffff'"></td>
          <td>cells </td>
          <td><input name=cell value=8 size=1  onmouseover="this.style.backgroundColor='#F0F0F0'" onmouseout="this.style.backgroundColor='#ffffff'"></td>
          <td id=jsq></td>
          </tr>
          </table><br><!-- color -->
          <input type="button" value='Color Style Design' onclick=sh() name=b0>

          <div id=w1 style="border:6 solid #7E84B8;display:none;left:20;top:20;width:510;overflow: auto;">
          <input type="button" value='Deeper Red' onclick=ct1()>
          <input type="button" value='Deeper Blue' onclick=ct2()>
          <input type="button" value='Apply' onclick=ini()>
          <div id=w2 ></div>
          <div id=w3 ></div>
          <input type="hidden" name=k1 value='#ffffff' size=10></td>
          <input type="hidden" name=k2 value='#ffffff' size=10></td>
          <input type="hidden" name=k3 value='#221616' size=10></td>
          <input type="hidden" name=k4 value='#221616' size=10></td>
          <input type="hidden" name=k5 value='#cdc8c8' size=10></td>
          <input type="hidden" name=k6 value='#ffffff' size=10></td>
          <input type="hidden" name=k7 value='#ffffff' size=10></td>
          <input type="hidden" name=k8 value='#cdc8c8' size=10></td>
          <input type="hidden" name=k9 value='#cdc8c8' size=10></td>
          <input type="hidden" name=k0 value='#ffffff' size=10></td>
          </div><br>Function:1.mouse right click to flag 2.color design 3.demo instantly<br>Debug enviroment:windows 98se && Internet Explorer 5.0<br>Author: Alex Lee E-mail:ae01@people.com.cn<br>Time: 2004/11/22 10:52 Beijing-times<br>Location:China PR
          </body>
          </html>  
             
            
          


          5楼2005-04-29 22:25
          回复
            那个。。


            6楼2005-07-09 17:17
            回复
              这是扫雷的源代码,分支switch不要用switch?,尽量是switch(){case:....
              default:....},其他问题我也找不出了~~水平还是太低


              7楼2005-07-09 17:42
              回复
                楼上是高人啊
                啥时候能收5为徒弟 


                删除|8楼2005-07-11 13:34
                回复
                  • 218.245.132.*
                  我也报名。
                  ——————合


                  9楼2005-07-11 19:25
                  回复