我嘗試準備簡單的聯繫表單與jquery,ajax和PHP沒有刷新。一切工作正常,除了event.preventDefault();
Jquery,PHP和Ajax的形式沒有刷新
這是我的文件:
contact_engine.php
<?php
$name = $_POST['name'];
...
$from = 'from';
$to = 'to';
$subject = 'subject';
$human = '4';
$body = ".........";
if ($_POST['submit'] && $human == '4') {
if (mail ($to, $subject, $body, $from)) {
echo '<p>Thanks</p>';
} else {
echo '<p>Error</p>';
}
} else if ($_POST['submit'] && $human != '4') {
echo '<p>You answered the anti-spam question incorrectly!</p>';
}
?>
阿賈克斯/ jQuery的
$('form').on('submit', function(event){
event.preventDefault();
$.ajax('.../contact_engine.php', {
type: 'POST',
data: $('form').serialize(),
success: function(result) {
}
});
});
PHP
<form method="post" action="<?php bloginfo('template_directory'); ?>/contact_engine.php">
<div class="box">
<input type="text" name="name" class="pola formbg name" placeholder="Name" />
.
.
.
.
<p><input id="form-button" type="submit" name="submit" value="Send" /></p>
</div>
<br style="clear: left;" />
</form>
當我刪除event.preventDefault();
一切都好,我收到來自表單的消息,但網站很清爽,我看到'感謝'的消息。
我用你可能看到的Wordpress。
您已標記wordpress,所以你可以看看https://codex.wordpress.org/AJAX_in_Plugins我不相信您的ajax網址正在運行$ .ajax('.../contact_engine.php', – Svetoslav
請注意,您的網址中有明顯的拼寫錯誤。除非你創建了一個名爲'...'的目錄,它應該是'../ contact_engine.php',而不是'.../contact_engine.php'。 –
你必須在這裏使用2個點,而不是3:'$ .ajax('.../contact_engine.php'' –