Rumah >hujung hadapan web >tutorial js >Javascript mencapai penambahan yang sama bagi nilai grid sembilan persegi kemahiran_javascript

Javascript mencapai penambahan yang sama bagi nilai grid sembilan persegi kemahiran_javascript

WBOY
WBOYasal
2016-05-16 15:13:571564semak imbas

Contoh dalam artikel ini memperkenalkan kaedah yang sepadan untuk merealisasikan Jiugongge dalam JavaScript dan berkongsi dengan semua orang untuk rujukan anda Kandungan khusus adalah seperti berikut

Idea pelaksanaan:
1. Nilai yang dimasukkan dalam setiap grid mestilah nombor;

2. Nilai yang dimasukkan tidak boleh diulang;

3. Nilai input tidak boleh kurang daripada 1 atau lebih besar daripada

4. Nilai tidak boleh kosong;

5. Terdapat 8 kaedah penambahan secara keseluruhan, termasuk tiga nilai mendatar, tiga menegak dan dua nilai pepenjuru. Butiran adalah seperti berikut:

Penjelasan:

Gunakan nombor siri yang ditanda dalam setiap grid sebagai pengecam:

Tiga nilai mendatar: 0-2, 3-4, 6-8

Tiga nilai menegak: [0,3,6], [1,4,7], [2,5,8];

Dua nilai pada pepenjuru: [0,4,8], [2,4,6]

Proses pelaksanaan:

Ianya sangat mudah, sama seperti gambar di atas, klik butang hantar untuk mula menilai.

1. Reka Letak

bahagian html:



bahagian css: dilaksanakan melalui atribut dalam 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. Seterusnya datang fokus, bahagian js
Saya telah menyebut kaedah pelaksanaan js sebelum ini, berikut adalah kod yang berkaitan.
*{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 Apabila nilai input bukan angka, atau lebih besar daripada 9, atau kurang daripada 0, atau kosong
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. Apabila memasukkan nombor berulang

3. Apabila input adalah betul


Di atas adalah keseluruhan kandungan artikel ini saya harap ia akan membantu semua orang dalam mempelajari pengaturcaraan javascript.

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn