Diskuze: Úprava dat v DB přes webovou stránku
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 4 zpráv z 4.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Tak je to cajk, vyřešeno takto:
<table class="table table-striped">
<thead>
<tr>
<th>ID</th>
<th>Jméno</th>
<th>Expy</th>
<th>Email</th>
</tr>
</thead>
<?php foreach ($uzivatele as $uzivatel): ?>
<tr>
<td><?= $uzivatel['ID'] ?></td>
<td><?= $uzivatel['jmeno'] ?></td>
<td><form method="post">
<input name="ID" value="<?= $uzivatel['ID'] ?>" type="hidden">
<input name="expy" class="form-control" type="number" value="<?= $uzivatel['expy'] ?>">
<button type="submit" class="btn btn-default">OK</button>
</form>
</td>
<td><?= $uzivatel['email'] ?></td>
</tr>
<?php endforeach; ?>
</table>
A potom v Kontroleru udělám pole s tou hodnotou expů a v DB se to upraví.
zdar, tak samozřejmě jde
nevim přesně, jaký nejlepší způsob je, ale můžeš pro každýho
uživatele udělat formulář a při kliknutí na sloupec se javascriptem
udělá input s příslušným name. Když pak klikneš enter (nebo třeba mimo
element), odešle se formulář.
Něco ve smyslu
<?php
if ($_POST) {
$userId = !empty($_POST["userId"] ? (int) $_POST["userId"] : 0;
if ($userId > 0) {
$change = array();
$keys = array("id", "name", "xp", "email");
foreach ($keys as $key) {
if (isset($_POST[$key])) {
$change[$key] = $_POST[$key];
}
}
if (!empty($change)) {
$db = new Db();
$db->update("user", $change); // vygeneruje dotaz, který provede update změněných hodnot v tabulce user
}
}
}
foreach ($users as $user) {
?>
<form method="post">
<input type="hidden" name="userId" value="<?php echo $user->id; ?>">
<tr>
<td><span onclick="createInput(this, 'id');"><?php echo $user->id; ?></span></td>
<td><span onclick="createInput(this, 'name');"><?php echo $user->name; ?></span></td>
<td><span onclick="createInput(this, 'xp');"><?php echo $user->xp; ?></span></td>
<td><span onclick="createInput(this, 'email');"><?php echo $user->email; ?></span></td>
</tr>
</form>
<?php
}
?>
<script type="text/javascript">
function createInput(span, name)
{
var input = document.createElement("input");
input.name = name;
input.value = span.innerHTML;
var td = span.parentNode;
td.removeElement(span);
td.appendChild(input);
}
</script>
prostě něco v takovém smyslu mě teď napadlo. S tím JS by sis musel trochu pohrát
Popravdě, JS jsem se chtěl trošku vyhnout a vyhnul jsem se, protože toto uplně neovládám a teď na to nemám vůbec časové ani vědomostní možnosti
Zobrazeno 4 zpráv z 4.