Stappenplan
In router.php
$route->get('items/create', 'controllers/items-create.php'); $route->post('items', 'controllers/items-store.php');
In controller items.create.php
<?php /* Indien je selectboxen hebt moet je hier waarschijnlijk gegevens uit de database ophalen om mee te geven aan de view. bv: $db = new Database(); view('items-create',[ 'categories' => $db->query("SELECT * FROM categories")->fetchAll() ]); */ view('items-create');
In view items-create.view.php
Hier komt een formulier met die kan worden verstuurd naar de route '/items' d.m.v. method=post
Versie zonder validatie en opnieuw invullen van velden
<?php view("parts/header", ['title' => 'item toevoegen']); view("parts/navigatie-menu"); ?> <h1 class="text-3xl my-4">Item toevoegen</h1> <form action="/items" method="post"> <?= csrf(); ?> <label for="naam">Naam</label><br> <input type="text" name="naam" id="naam" placeholder="naam"><br> <label for="beschrijving">Beschrijving</label><br> <textarea name="beschrijving" id="beschrijving" cols="30" rows="3" placeholder="beschrijving"></textarea><br> <label for="prijs">Prijs</label><br> <input type="number" step="0.01" name="prijs" id="prijs" placeholder="prijs"><br> <input type="submit" value="Toevoegen" class="border b-gray-600 rounded py-1 px-2 hover:bg-gray-100 cursor-pointer"> <?php view("parts/footer");
Versie met validatie en opnieuw invullen van velden
<?php view("parts/header", ['title' => 'item toevoegen']); view("parts/navigatie-menu"); ?> <h1 class="text-3xl my-4">Item toevoegen</h1> <form action="/items" method="post"> <?= csrf(); ?> <label for="naam">Naam</label><br> <input type="text" name="naam" id="naam" placeholder="naam" value="<?= $_POST['naam'] ?? '' ?>"><br> <?php if (isset($errors['naam'])): ?> <p class="text-red-500 text-sm my-2"><?= $errors['naam'] ?></p> <?php endif; ?> <label for="beschrijving">Beschrijving</label><br> <textarea name="beschrijving" id="beschrijving" cols="30" rows="3" placeholder="beschrijving"><?= $_POST['beschrijving'] ?? '' ?></textarea> <br> <?php if (isset($errors['beschrijving'])): ?> <p class="text-red-500 text-sm my-2"><?= $errors['beschrijving'] ?></p> <?php endif; ?> <label for="prijs">Prijs</label><br> <input type="number" step="0.01" name="prijs" id="prijs" placeholder="prijs" value="<?= $_POST['prijs'] ?? '' ?>"> <br> <?php if (isset($errors['prijs'])): ?> <p class="text-red-500 text-sm my-2"><?= $errors['prijs'] ?></p> <?php endif; ?> <input type="submit" value="Toevoegen" class="border b-gray-600 rounded py-1 px-2 hover:bg-gray-100 cursor-pointer"> <?php view("parts/footer");
In controller items-store.php
<?php //validatie van de gegevens require "../src/Validator.php"; $errors = []; //lege array voor de foutmeldingen if (!Validator::required($_POST['naam'])) { $errors['naam'] = "Naam is verplicht"; } if (!Validator::length($_POST['naam'], 0, 50)) { $errors['naam'] = "Naam mag niet langer zijn dan 50 tekens"; } if (!Validator::between($_POST['prijs'], 0.01, 1000000)) { $errors['naam'] = "De prijs moet tussen 0,01 en 1.000.000 liggen"; } //voor alle validatie regels zie cheat-sheet //indien niet oké terugsturen naar de create pagina met foutmeldingen if (!empty($errors)) { view('items-create', [ 'errors' => $errors ]); exit(); } //indien validatie oké dan gegevens opslaan in de database $db = new Database(); $db->query("INSERT INTO items (naam,beschrijving,prijs) VALUES (:naam,:beschrijving,:prijs)", [ 'naam' => $_POST['naam'], 'beschrijving' => $_POST['beschrijving'], 'prijs' => $_POST['prijs'] ]); //id veld staat op auto increment dus hoeft niet meegegeven te worden flash("Item " . htmlspecialchars($_POST['naam']) . " is toegevoegd"); //terugsturen naar de index pagina header("location: /items"); //terugsturen naar de detail pagina van het item //header("location: /items/" . $db->lastInsertId());