Advertisement
Guest User

Untitled

a guest
Dec 13th, 2019
89
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>Iks - Oks / Danijel Obradovic NRT-79/12</title>
  6.  
  7.     <style>
  8.         .polje {
  9.             border: 1px solid #666;
  10.             box-sizing: border-box;
  11.             display: inline-block;
  12.             font-size: 32px;
  13.             height: 100px;
  14.             line-height: 100px;
  15.             text-align: center;
  16.             width: 100px;
  17.         }
  18.  
  19.         .polje .sadrzaj {
  20.             display: inline-block;
  21.             vertical-align: middle;
  22.         }
  23.  
  24.         #reset {
  25.             margin-top: 20px;
  26.         }
  27.     </style>
  28. </head>
  29. <body>
  30. <p>Trenutno igra: <span id="trenutni-igrac"></span></p>
  31.  
  32. <div id="tabla"></div>
  33.  
  34. <button id="reset">Nova igra</button>
  35.  
  36. <script>
  37.     const trenutniIgrac = document.querySelector('#trenutni-igrac');
  38.     const tabla =  document.querySelector('#tabla');
  39.     const resetDugme =  document.querySelector('#reset');
  40.  
  41.     function inicijalizujStanje() {
  42.         return {
  43.             modelTable:[
  44.                 [null, null, null],
  45.                 [null, null, null],
  46.                 [null, null, null]
  47.             ],
  48.             igraci: ['X', 'O'],
  49.             trenutniIgrac: 0,
  50.             kraj: false,
  51.             potez: 0,
  52.         };
  53.     }
  54.  
  55.     stanje = inicijalizujStanje();
  56.  
  57.     function prikaziTablu() {
  58.         trenutniIgrac.textContent = stanje.igraci[stanje.trenutniIgrac];
  59.  
  60.         tabla.innerHTML = '';
  61.  
  62.         for (let i = 0; i < 3; i++) {
  63.             const red = document.createElement('div');
  64.             red.classList.add('red');
  65.  
  66.             for (let j = 0; j < 3; j++) {
  67.                 const polje = document.createElement('div');
  68.                 polje.classList.add('polje');
  69.                 polje.setAttribute('data-i', i);
  70.                 polje.setAttribute('data-j', j);
  71.  
  72.                 const sadrzaj = document.createElement('span');
  73.                 sadrzaj.classList.add('sadrzaj');
  74.                 sadrzaj.textContent = stanje.modelTable[i][j];
  75.                 polje.appendChild(sadrzaj);
  76.                 red.appendChild(polje);
  77.             }
  78.  
  79.             tabla.appendChild(red);
  80.         }
  81.     }
  82.  
  83.     function zakaciListenere() {
  84.         tabla.addEventListener('click', event => {
  85.             if (stanje.kraj) {
  86.                 return;
  87.             }
  88.  
  89.             if (!event.target.classList.contains('polje')) {
  90.                 return;
  91.             }
  92.  
  93.             const polje = event.target;
  94.             const i = parseInt(polje.getAttribute('data-i'), 10);
  95.             const j = parseInt(polje.getAttribute('data-j'), 10);
  96.  
  97.             if (stanje.modelTable[i][j] !== null) {
  98.                 alert('Ovo polje je vec popunjeno!');
  99.  
  100.                 return;
  101.             }
  102.  
  103.             const igrac = stanje.igraci[stanje.trenutniIgrac];
  104.             stanje.modelTable[i][j] = igrac;
  105.  
  106.             const pobedonosniPokret = proveraPobede(stanje.modelTable, igrac);
  107.  
  108.             stanje.potez++;
  109.  
  110.             if (!pobedonosniPokret) {
  111.                 stanje.trenutniIgrac = (stanje.trenutniIgrac + 1) % 2;
  112.  
  113.                 prikaziTablu();
  114.  
  115.                 if (stanje.potez === 9) {
  116.                     alert('Odigrali ste nereseno!');
  117.                 }
  118.             } else {
  119.                 prikaziTablu();
  120.  
  121.                 stanje.kraj = true;
  122.  
  123.                 alert(`Igrac ${igrac} je pobedio!`);
  124.             }
  125.         });
  126.  
  127.         resetDugme.addEventListener('click', () => {
  128.             if (confirm('Da li zelite da pokrenete novu igru?')) {
  129.                 stanje = inicijalizujStanje();
  130.  
  131.                 prikaziTablu();
  132.             }
  133.         });
  134.     }
  135.  
  136.     function proveraPobede(tabla, igrac) {
  137.         // Proveri horizontalno.
  138.         for (let i = 0; i < 3; i++) {
  139.             if (tabla[i].every(polje => polje === igrac)) {
  140.                 return true;
  141.             }
  142.         }
  143.  
  144.         // Proveri vertikalno.
  145.         for (let j = 0; j < 3; j++) {
  146.             let imamoLiPobednika = true;
  147.  
  148.             for (let i = 0; i < 3; i++) {
  149.                 if (tabla[i][j] !== igrac) {
  150.                     imamoLiPobednika = false;
  151.  
  152.                     break;
  153.                 }
  154.             }
  155.  
  156.             if (imamoLiPobednika) {
  157.                 return imamoLiPobednika;
  158.             }
  159.         }
  160.  
  161.         // Proveri dijagonalno - od juga ka istoku.
  162.         let imamoLiPobednika = true;
  163.  
  164.         for (let i = 0; i < 3; i++) {
  165.             if (tabla[i][i] !== igrac) {
  166.                 imamoLiPobednika = false;
  167.  
  168.                 break;
  169.             }
  170.         }
  171.  
  172.         if (imamoLiPobednika) {
  173.             return imamoLiPobednika;
  174.         }
  175.  
  176.         // Proveri dijagonalno - od severa ka istoku.
  177.         imamoLiPobednika = true;
  178.  
  179.         for (let i = 3 - 1, j = 0; i >= 0; i--, j++) {
  180.             if (tabla[i][j] !== igrac) {
  181.                 imamoLiPobednika = false;
  182.  
  183.                 break;
  184.             }
  185.         }
  186.  
  187.         if (imamoLiPobednika) {
  188.             return imamoLiPobednika;
  189.         }
  190.  
  191.         return false;
  192.     }
  193.  
  194.     prikaziTablu();
  195.     zakaciListenere();
  196. </script>
  197. </body>
  198. </html>
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement