Как создать сообщение об успехе в div после успешной отправки формы?
следующая форма отображает сообщение об успехе каждый раз при запуске страницы в браузере логически, но форма должна отображать сообщение об успехе только после его успешной отправки.
$editFormAction = $_SERVER['PHP_SELF'];
if (isset($_SERVER['QUERY_STRING'])) {
$editFormAction .= "?" . htmlentities($_SERVER['QUERY_STRING']);
}
$message = "Record has been updated successfully.";
if ((isset($_POST["MM_update"])) && ($_POST["MM_update"] == "form1")) {
$updateSQL = sprintf("UPDATE table SET name=%s, email=%s,
GetSQLValueString($_POST['name'], "text"),
GetSQLValueString($_POST['email'], "text"),
mysql_select_db($database_test, $test);
$Result1 = mysql_query($updateSQL, $test) or die(mysql_error());
$updateGoTo = "test.php";
if (isset($_SERVER['QUERY_STRING'])) {
$updateGoTo .= (strpos($updateGoTo, '?')) ? "&" : "?";
$updateGoTo .= $_SERVER['QUERY_STRING'];
}
header(sprintf("Location: %s", $updateGoTo));
}
html-часть формы выглядит следующим образом:
<form action="<?php echo $editFormAction; ?>" method="post" name="form1" id="form1">
<table align="center" class="test_table">
<tr valign="baseline">
<td align="right" nowrap="nowrap" class="table-title">Name:</td>
<td class="table-content"><input type="text" name="name" value="<?php echo htmlentities($row_user['name'], ENT_COMPAT, 'utf-8'); ?>" size="32" /></td>
</tr>
<tr valign="baseline">
<td align="right" nowrap="nowrap" class="table-title">E-mail:</td>
<td class="table-content"><input type="text" name="email" value="<?php echo htmlentities($row_user['email'], ENT_COMPAT, 'utf-8'); ?>" size="32" /></td>
</tr>
</table>
<input type="hidden" name="MM_update" value="form1" />
<input type="hidden" name="id" value="<?php echo $row_user['id']; ?>" />
<input class="submit" name="UpdateRecord" type="submit" id="UpdateRecord" value="Update Record" /></form>
вот как сообщение об успехе отображается в div на странице:
<p> <?php
if (!empty($message)) {
echo "<div class="successmessage">" . $message . "</div>";
}
?></p>
что я здесь делаю не так?
3 ответов
Я создал две функции, чтобы показать
function addMessageStack($message,$type='success')
{
$_SESSION['sess_MessageStack'][] = array($type,$message);
}
function showMessageStack()
{
$str = '';
if(count($_SESSION['sess_MessageStack']) > 0)
{
for($i=0;$i<count($_SESSION['sess_MessageStack']);$i++)
{
$str.="<div class='".$_SESSION['sess_MessageStack'][$i][0]."Message left'>".$_SESSION['sess_MessageStack'][$i][1]."</div>";
}
unset($_SESSION['sess_MessageStack']);
return $str;
}
}
в вашем примере Используйте, как показано ниже
addMessageStack('Record has been updated successfully.');
header(sprintf("Location: %s", $updateGoTo));
exit;
для сообщения dispaly убедитесь, что есть session_start ();
<?php echo showMessageStack(); ?>
он отобразит ваше сообщение после отправки формы только
hRaval, большое спасибо за ваше ценное руководство с самого начала и окончательный намек.
следующее дополнение к addMessageStack решает проблему окончательно.
$message = "Record Has Been Updated Successfully";
addMessageStack("<div class=\"successmessage\">" . $message . "</div>");
С уважением,
Это можно сделать более просто, сохранив сообщение об успехе в выбранной переменной или массиве или сеансе после выполнения запроса и подсчета строки без написания длинной функции.
// простой метод
mysql_select_db($database_test, $test);
$Result1 = mysql_query($updateSQL, $test) or die(mysql_error());
$Row_Count = mysql_num_rows($Result1);
if ($Row_Count > 0){
$successmessage = "Edited Successfully";
}
или
/ / если вы хотите сохранить все другие сообщения об успехе, включая это, в массиве.
mysql_select_db($database_test, $test);
$Result1 = mysql_query($updateSQL, $test) or die(mysql_error());
$Row_Count = mysql_num_rows($Result1);
if ($Row_Count > 0){
$successmessage[] = "Edited Successfully";
}
или
// если вы хотите определить местоположение заголовка после успешной исполнение.
mysql_select_db($database_test, $test);
$Result1 = mysql_query($updateSQL, $test) or die(mysql_error());
$Row_Count = mysql_num_rows($Result1);
if ($Row_Count > 0){
$_SESSION['successmessage'] = "Edited Successfully";
}
затем во всех случаях выше вы можете вызвать сообщение об успехе в любом месте документа, который вы хотите, проверив, установлена ли переменная или не пуста. Я приведу пример ниже для простейшего метода, объясненного выше.
if(isset($successmessage)){
echo "<div id=\"MyDesiredDiv\">" .$successmessage. "</div>";
}
или
if(!empty($successmessage)){
echo "<div id=\"MyDesiredDiv\">" .$successmessage. "</div>";
}
важное примечание: MySql устарел давно. Попробуйте использовать MySqli или PDO и следуйте приведенному выше методу.