
本文旨在解决PHP表单提交后,刷新页面时浏览器提示“确认重新提交表单”以及页面重复显示结果的问题。通过使用JavaScript防止表单重复提交,并结合PHP代码处理表单数据,确保用户体验的流畅性,避免不必要的重复操作。本文提供了一种无需重定向的解决方案,保持页面状态的同时避免重复提交。
在PHP开发中,经常会遇到表单提交后刷新页面导致重复提交的问题。这不仅会影响用户体验,还可能导致数据错误。下面我们将通过一个简单的示例,演示如何解决这个问题。
示例代码
<?php
$db_fruit = 'apple';
$db_vegetable = 'tomato';
$result = array();
if (isset($_POST['fruit']) && isset($_POST['vegetable'])) {
$fruit= htmlentities($_POST['fruit']);
$vegetable = htmlentities($_POST['vegetable']);
if (!empty($fruit) && !empty($vegetable)) {
if ($fruit == $db_fruit && $vegetable == $db_vegetable) {
$result[] = 'The values do match.';
} else {
$result[] = 'The values do not match.';
}
}
}
if (!empty($result)) {
foreach ($result as $val) {
echo "$val";
}
}
?>
<script>
//this part will not allow form resubmit on refresh !
if ( window.history.replaceState ) {
window.history.replaceState( null, null, window.location.href );
}
</script>
<form action="" method="POST">
<input type="text" name="fruit" placeholder="FRUIT HERE"><br>
<input type="text" name="vegetable" placeholder="VEGETABLE HERE">
<button type="submit">CHECK</button>
</form>代码解释
立即学习“PHP免费学习笔记(深入)”;
PHP部分:
JavaScript部分:
HTML部分:
工作原理
当用户填写表单并点击提交按钮后,PHP 代码会处理表单数据,并将结果显示在页面上。然后,JavaScript 代码会修改浏览器的历史记录,防止用户刷新页面时重复提交表单。
注意事项
总结
通过结合 PHP 代码和 JavaScript 代码,我们可以有效地解决 PHP 表单提交后刷新页面导致重复提交的问题,提高用户体验。该方法简单易懂,易于实现,适用于各种 PHP 项目。
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号