Heim  >  Artikel  >  Web-Frontend  >  Javascript erkennt, dass der Neun-Quadrat-Raster-Additionswert gleich ist_Javascript-Fähigkeiten

Javascript erkennt, dass der Neun-Quadrat-Raster-Additionswert gleich ist_Javascript-Fähigkeiten

WBOY
WBOYOriginal
2016-05-16 15:13:571536Durchsuche

Das Beispiel in diesem Artikel stellt die entsprechende Methode zur Implementierung von Jiugongge in JavaScript vor und teilt sie als Referenz mit allen. Der spezifische Inhalt ist wie folgt

Umsetzungsideen:
1. Der in jedes Raster eingegebene Wert muss eine Zahl sein;

2. Der eingegebene Wert kann nicht wiederholt werden

3. Der Eingabewert darf nicht kleiner als 1 oder größer als 9 sein;

4. Der Wert darf nicht leer sein

5. Es gibt insgesamt 8 Additionsmethoden, darunter drei horizontale, drei vertikale und zwei diagonale Werte. Details sind wie folgt:

Erklärung:

Verwenden Sie die in jedem Raster markierte Seriennummer als Kennung:

Drei horizontale Werte: 0-2, 3-4, 6-8;

Drei vertikale Werte: [0,3,6], [1,4,7], [2,5,8];

Zwei Werte auf der Diagonale: [0,4,8], [2,4,6]

Implementierungsprozess:

Es ist ganz einfach, genau wie im Bild oben: Klicken Sie auf die Schaltfläche „Senden“, um mit der Bewertung zu beginnen.

1. Layout

HTML-Teil:



CSS-Teil: implementiert durch Attribute in CSS3.
<div class="box">
  <input type="text">
  <input type="text">
  <input type="text">
  <input type="text">
  <input type="text">
  <input type="text">
  <input type="text">
  <input type="text">
  <input type="text">
  <button>提交</button>
</div>


2. Als nächstes kommt der Fokus, der js-Teil
Ich habe bereits über die js-Implementierungsmethode gesprochen. Hier ist der entsprechende Code.
*{margin:0;padding:0;outline: none;}
html,body{
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.box{
  position: relative;
  width: 250px;
  margin:0 auto;
}
input{
  text-align: center;
  font: 40px/60px 'Microsoft YaHei';
  width: 30%;
  float:left;
  box-sizing:border-box
}
button{
  position: absolute;
  bottom:-30px;
  left: 50%;
  margin-left: -30px;
  width: 40px;
}



1. Wenn der Eingabewert nicht numerisch oder größer als 9 oder kleiner als 0 ist oder leer ist
var oBtn=document.getElementsByTagName('button')[0],
  aInp=document.getElementsByTagName('input');
function isNum(){
  var aTemp=[];//创建临时函数,一次存放九宫格中的数字
  for(i=0;i<aInp.length;i++)
  {
  var val=Number(aInp[i].value);
  if(isNaN(val) || val<1 || val>9) {//判断当前输入框中数值是否是数字,是否小于1,是否大于9?
    alert('1、您只能输入1-9纯数字;2、不能为空;');
    return false;//若满足任意一条件直接退出函数不往下走
  }
  for(s=0;s<aTemp.length;s++){//循环判断九宫格内是否有重复数值,若是有重复直接推出函数
    if(val == aTemp[s]){
      alert('不能重复输入!');
      return false;
    }
  }
  //上述判断都满足,则将当前val的值放到数组aTemp中
  aTemp.push(val);
  }
  //n后面所跟数字与上面图片每个格子标记的数值一致
  //将横向与纵向的值设置为0;其中n1-n3为横向三个值,n4-n6为纵向三个值
  var n1=0,n2=0,n3=0,n4=0,n5=0,n6=0,
  //n7、n8分别为两对角值
  n7=aTemp[0]+aTemp[4]+aTemp[8],
  n8=aTemp[2]+aTemp[4]+aTemp[6];
  //横向:分段相加值
  for(i=0;i<3;i++)n1+=aTemp[i];
  for(i=3;i<6;i++)n2+=aTemp[i];
  for(i=6;i<9;i++)n3+=aTemp[i];
  //纵向:因为纵向是每隔两个格子相加一次,所以正好用取模方式计算
  
  for(i=0;i<9;i++){
  (i%3==0) && (n4+=aTemp[i]);//当i%3=0时,分别为格子0、3、6
  (i%3==1) && (n5+=aTemp[i]);//当i%3=1时,分别为格子1、4、7
  (i%3==2) && (n6+=aTemp[i]);//当i%3=1时,分别为格子2、5、8
  }
  //判断n1-n8各值是否都相等,当然可以任意一个n判断,不局限只与n1的值相等
  n1==n2 && n1==n3 && n1==n4 && n1==n5 && n1==n6 && n1==n7 && n1==n8 &#63; alert('恭喜您输入正确!') : alert('很遗憾您输入错误!');
}
oBtn.onclick=isNum;执行效果

2. Bei der Eingabe wiederholter Zahlen

3. Wenn die Eingabe korrekt ist


Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er für alle beim Erlernen der Javascript-Programmierung hilfreich sein wird.

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn