我正在尝试使用jquery post来尝试将表单数据异步发送到将上传数据到我的数据库的php文件。
<!DOCTYPE html>
<html>
<head>
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
</head>
<body>
<div id="contact_form">
<form id="contact" name="contact" method="post">
<fieldset>
<label for="name" id="name_label">Name</label>
<input type="text" name="name" id="name" size="30" value="" class="text-input" />
<label for="email" id="email_label">Return Email</label>
<input type="text" name="email" id="email" size="30" value="" class="text-input" />
<label for="phone" id="phone_label">Return Phone</label>
<input type="text" name="phone" id="phone" size="30" value="" class="text-input" />
<br />
<input type="submit" name="submit" class="button" id="submit_btn" value="Submit" />
</fieldset>
</form>
</div>
<div id="result"></div>
<script>
$(document).ready(function(){
/* attach a submit handler to the form */
$("#submit_btn").submit(function(event) {
/* stop form from submitting normally */
event.preventDefault();
$.post("process.php", $("#contact").serialize());
return false;
});
});
</script>
</body>
</html>
我知道它是对数据进行串行编码,但是我的php脚本没有把它拿起来,我不确定我做错了什么。我知道这很简单,但我已经在这几天工作,似乎无法弄明白。我知道如何在没有jquery的情况下做到这一点,但在这种情况下我真的需要它。这是我的php:
if(isset($_POST['submit']))
{
$var_name = $_POST['name'];
$var_email = $_POST['email'];
$var_phone = $_POST['phone'];
//This establishes a connection to the database. It also says what to do if the connection fails.
try {
$db_handle = new PDO("mysql:host=$server;dbname=$database", $db_username, $db_password);
$db_handle->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$stmt = $db_handle->prepare('INSERT INTO contact(name, email, phone) VALUES(:name, :email, :phone)');
$stmt->execute(array(
':name' => $var_name,
':email' => $var_email,
':phone' => $var_phone,
));
} catch(PDOException $e) {
echo 'Error: ' . $e->getMessage();
}
}
答案 0 :(得分:1)
$("contact").serialize()
应该是:
$("#contact").serialize()
您的选择器不正确,因此您实际上并未向服务器发送任何内容。下次,在浏览器工具中查看请求。
答案 1 :(得分:0)
http://api.jquery.com/serialize/
jquery API声明不会传递提交按钮值。所以帖子可能会收到你的php请求就好了,建议你找一个必填字段,而不是在你的条件中寻找$ _POST ['submit']。
您也可以尝试在代码之前使用var_dump($ _ POST),看看脚本的内容是什么。
答案 2 :(得分:0)
使用jQuery序列化表单时,不包括提交按钮,因此您应该替换
if(isset($_POST['submit']))
通过
if ($_SERVER['REQUEST_METHOD'] === 'POST')
修改强>
按$("#submit_btn").submit(...);
$("#contact").submit(...);