Er is geen <form>
het inkapselen van de invoer elementen. Bovendien moet je een <input type="submit" ... >
. gebruiken element in plaats van ankertag om de ingevoerde gegevens van de gebruiker naar itemedit.php te sturen bladzijde. Dus verander je for
loop op de volgende manier,
for($i=1;$i<=$menuSet->GetMenuItems();$i++){
$func = "GetMenuLink".$i;
?>
<tr>
<form action="itemedit.php?i=<?php echo $i; ?>" method="post">
<td>$i</td>
<td><input type='text' name='e' value='<?php echo $menuSet->$func(); ?>'/></td>
<td>
<input type='submit' value='Edit' class='glyphicon glyphicon-pencil' />
</form>
<a title='Remove' href='itemdelete.php?i=<?php echo $i; ?>'><span class='glyphicon glyphicon-remove'></span></a>
</td>
</tr>
<?php
}
En in itemedit.php pagina, verwerk de ingediende gegevens van uw formulier op de volgende manier,
if (isset($_GET['i'])){
$i = $_GET['i'];
$e = $_POST['e'];
$editItem = new Menus();
// update the menu items
$editItem->EditMenuItem($i,$e);
...
Bijwerken(1):
Uw voorbereide verklaring en bindParam()
methode-aanroep is ook verkeerd. Die zouden zo moeten zijn:
$adm = $this->db->prepare("UPDATE menu_nav SET menu_link_$i = ?");
$adm->bindParam(1, $e, PDO::PARAM_STR);