I lettori come te aiutano a sostenere MUO. Quando effettui un acquisto utilizzando i link sul nostro sito, potremmo guadagnare una commissione di affiliazione. Per saperne di più.

Tic-tac-toe è un gioco popolare che utilizza una griglia 3×3. L'obiettivo del gioco è essere il primo giocatore a posizionare tre simboli in una riga orizzontale, verticale o diagonale.

Puoi creare un gioco Tic-tac-toe che viene eseguito in un browser Web utilizzando HTML, CSS e JavaScript. Puoi utilizzare HTML per aggiungere il contenuto che contiene la griglia 3×3 e CSS per aggiungere un po' di stile al design del gioco.

Puoi quindi utilizzare JavaScript per la funzionalità del gioco. Ciò include il posizionamento dei simboli, i turni tra i giocatori e la decisione su chi vince.

Come creare l'interfaccia utente per il gioco Tic-Tac-Toe

Puoi leggere e scaricare il codice sorgente completo di questo gioco dal suo Deposito GitHub.

Tic-tac-toe è uno dei tanti giochi che puoi fare quando impari a programmare. È buono praticare una nuova lingua o ambiente, come il motore di sviluppo del gioco PICO-8.

instagram viewer

Per creare un gioco Tic-tac-toe che gira in un browser web, dovrai aggiungere codice HTML per il contenuto della pagina. Puoi quindi modellarlo usando i CSS.

  1. Crea un nuovo file chiamato "index.html".
  2. All'interno di "index.html", aggiungi la struttura di base di un file HTML:
    html>
    <htmllang="en-US">
    <Testa>
    <titolo>Gioco Tic Tac Toetitolo>
    Testa>
    <corpo>

    corpo>
    html>
  3. All'interno del tag body HTML, aggiungi una tabella che contenga tre righe, con tre celle in ogni riga:
    <divclasse="contenitore">
    <tavolo>
    <tr>
    <tdid="1">td>
    <tdid="2">td>
    <tdid="3">td>
    tr>
    <tr>
    <tdid="4">td>
    <tdid="5">td>
    <tdid="6">td>
    tr>
    <tr>
    <tdid="7">td>
    <tdid="8">td>
    <tdid="9">td>
    tr>
    tavolo>
    div>
  4. Nella stessa cartella del tuo file HTML, crea un nuovo file chiamato "styles.css".
  5. All'interno del file CSS, aggiungi uno stile alla tua griglia 3 per 3:
    tavolo {
    crollo del bordo: crollo;
    margine: 0 auto;
    }

    td {
    larghezza: 100px;
    altezza: 100px;
    allineamento del testo: centro;
    allineamento verticale: mezzo;
    confine: 1pxsolidonero;
    }

  6. Collega il file CSS al tuo file HTML aggiungendolo al tag head:
    <collegamentorel="foglio di stile"tipo="testo/css"href="stili.css">

Come fare a turno aggiungendo simboli al tabellone di gioco

Nel gioco ci saranno due giocatori, ciascuno con un simbolo "X" o "O". È possibile aggiungere un simbolo "X" o "O" facendo clic su una delle celle della griglia. Questo continuerà finché uno di voi non avrà creato una fila orizzontale, verticale o diagonale diritta.

Puoi aggiungere questa funzionalità utilizzando JavaScript.

  1. Nella stessa cartella dei tuoi file HTML e CSS, crea un file JavaScript chiamato "script.js".
  2. Collega il file JavaScript al tuo file HTML aggiungendo lo script in fondo al tag body:
    <corpo>
    Il tuo codice qui
    <copionesrc="script.js">copione>
    corpo>
  3. All'interno del file JavaScript, aggiungi una stringa per rappresentare il simbolo del giocatore. Questo può essere "X" o "O". Per impostazione predefinita, il primo giocatore posizionerà una "X":
    permettere giocatoreSymbol = "X";
  4. Aggiungi un'altra variabile per tenere traccia della fine del gioco:
    permettere giocoFine = falso
  5. Ogni cella nella tabella HTML ha un ID compreso tra 1 e 9. Per ogni cella della tabella, aggiungi un listener di eventi che verrà eseguito ogni volta che un utente fa clic sulla cella:
    per (permettere io = 1; io <= 9; i++) {
    documento.getElementById (i.toString()).addEventListener(
    "clic",
    funzione() {

    }
    );
    }
  6. All'interno del listener di eventi, modificare l'HTML interno per visualizzare il simbolo corrente. Assicurati di usare un'istruzione condizionale JavaScript per assicurarsi innanzitutto che la cella sia vuota e che il gioco non sia ancora terminato:
    Se (Questo.innerHTML "" && !gameEnded) {
    Questo.innerHTML = playerSymbol;
    }
  7. Aggiungi una classe all'elemento HTML per definire lo stile del simbolo che verrà visualizzato sulla griglia. Il nome delle classi CSS sarà "X" o "O", a seconda del simbolo:
    Questo.classList.add (playerSymbol.toLowerCase());
  8. All'interno del file "styles.css", aggiungi queste due nuove classi per i simboli "X" e "O". I simboli "X" e "O" verranno visualizzati con colori diversi:
    .X {
    colore: blu;
    dimensione del font: 80px;
    }

    .o {
    colore: rosso;
    dimensione del font: 80px;
    }

  9. Nel file JavaScript, dopo aver modificato innerHTML per visualizzare il simbolo, scambia il simbolo. Ad esempio, se il giocatore ha appena posizionato una "X", cambia il simbolo successivo in "O":
    Se (giocatoreSimbolo "X")
    giocatoreSymbol = "Oh"
    altro
    giocatoreSymbol = "X"
  10. Per eseguire il gioco, apri il file "index.html" in un browser Web per visualizzare la griglia 3 per 3:
  11. Inizia a posizionare i simboli sulla griglia facendo clic sulle celle. Il gioco alternerà i simboli "X" e "O":

Come determinare il vincitore

Al momento, il gioco continuerà anche se un giocatore ha piazzato tre simboli consecutivi. Dovrai aggiungere una condizione finale per verificarla dopo ogni turno.

  1. All'interno del tuo file JavaScript, aggiungi una nuova variabile per memorizzare tutte le possibili posizioni "vincenti" per la griglia 3 per 3. Ad esempio, "[1,2,3]" è la riga superiore o "[1,4,7]" è una riga diagonale.
    permettere winPos = [
    [1, 2, 3], [4, 5, 6],
    [7, 8, 9], [1, 4, 7],
    [2, 5, 8], [3, 6, 9],
    [1, 5, 9], [3, 5, 7]
    ];
  2. Aggiungi una nuova funzione chiamata checkWin():
    funzionecheckWin() {

    }
  3. All'interno della funzione, scorri ciascuna delle possibili posizioni vincenti:
    per (permettere io = 0; i < winPos.lunghezza; i++) {

    }

  4. All'interno del ciclo for, controlla se tutte le celle contengono il simbolo del giocatore:
    Se (
    documento.getElementById (winPos[i][0]).innerHTML playerSimbolo &&
    documento.getElementById (winPos[i][1]).innerHTML playerSimbolo &&
    documento.getElementById (winPos[i][2]).innerHTML playerSymbol
    ) {

    }

  5. Se la condizione restituisce true, tutti i simboli sono in linea retta. All'interno dell'istruzione if, mostra un messaggio all'utente. Puoi anche modificare lo stile dell'elemento HTML aggiungendo una classe CSS chiamata "win":
    documento.getElementById (winPos[i][0]).classList.add("vincita");
    documento.getElementById (winPos[i][1]).classList.add("vincita");
    documento.getElementById (winPos[i][2]).classList.add("vincita");
    giocoFine = VERO;

    setTimeout(funzione() {
    avviso (playerSymbol + "vince!");
    }, 500);

  6. Aggiungi questa classe CSS "vincente" al file "styles.css". Quando il giocatore vince, cambierà il colore di sfondo delle celle vincenti in giallo:
    .vincita {
    colore di sfondo: giallo;
    }
  7. Chiama la funzione checkWin() ogni volta che un giocatore ha un turno, all'interno del gestore eventi aggiunto nei passaggi precedenti:
    per (permettere io = 1; io <= 9; i++) {
    // Ogni volta che un giocatore fa clic su una cella
    documento.getElementById (i.toString()).addEventListener(
    "clic",
    funzione() {
    Se (Questo.innerHTML "" && !gameEnded) {
    // Visualizza "X" o "O" nella cella e applica uno stile
    Questo.innerHTML = playerSymbol;
    Questo.classList.add (playerSymbol.toLowerCase());

    // Controlla se un giocatore ha vinto
    checkWin();

    // Scambia il simbolo con l'altro per il turno successivo
    Se (giocatoreSimbolo "X")
    giocatoreSymbol = "Oh"
    altro
    giocatoreSymbol = "X"
    }
    }
    );
    }

Come reimpostare il tabellone di gioco

Una volta che un giocatore ha vinto la partita, puoi ripristinare il tabellone di gioco. Puoi anche reimpostare il tabellone di gioco in caso di pareggio.

  1. Nel file HTML, dopo la tabella, aggiungi un pulsante di ripristino:
    <pulsanteid="Ripristina">Ripristinapulsante>
  2. Aggiungi uno stile al pulsante di ripristino:
    .contenitore {
    Schermo: flettere;
    direzione flessibile: colonna;
    }

    #Ripristina {
    margine: 48px 40%;
    imbottitura: 20px;
    }

  3. Nel file JavaScript, aggiungi un gestore di eventi che verrà eseguito ogni volta che l'utente fa clic sul pulsante di ripristino:
    documento.getElementById("Ripristina").addEventListener(
    "clic",
    funzione() {

    }
    );

  4. Per ogni cella della griglia, ottieni l'elemento HTML utilizzando la funzione getElementById(). Reimposta innerHTML per rimuovere i simboli "O" e "X" e rimuovere tutti gli altri stili CSS:
    per (permettere io = 1; io <= 9; i++) {
    documento.getElementById (i.toString()).innerHTML = "";
    documento.getElementById (i.toString()).classList.remove("X");
    documento.getElementById (i.toString()).classList.remove("o");
    documento.getElementById (i.toString()).classList.remove("vincita");
    giocoFine = falso;
    }
  5. Avvia il gioco aprendo il file "index.html" in un browser web.
  6. Inizia a posizionare i simboli "X" e "O" sulla griglia. Prova a far vincere uno dei simboli.
  7. Premere il pulsante di ripristino per ripristinare il tabellone di gioco.

Imparare JavaScript creando giochi

Puoi continuare a migliorare le tue capacità di programmazione creando più progetti in JavaScript. È facile creare giochi e strumenti semplici in un ambiente Web, utilizzando tecnologie aperte multipiattaforma come JavaScript e HTML.

Non c'è modo migliore per migliorare la tua programmazione che esercitarsi a scrivere programmi!