我正在尝试实现一个简单的表单,该表单最终将连接到数据库并在其中进行输入。在标签中,我正在调用php文件,它将把我连接到后端的数据库。
index.html
<html>
<head>
<script>
function submitForm(formId){
//var formData= $.(formId).serialize();
$.ajax({
url:'new-user.php',
type:'POST',
data:{
user_name=$("#user_name").val(),
password=$("#password").val();
}
success:function(response){
alert(response);
}
});
}
</script>
</head>
<body>
<form onsubmit="submitForm('#myForm');" id='myForm'>
User Name: <input type="text" name="user_name" id="user_name" />
Password: <input type="text" name="password" id="password" />
<input type="submit"/>
</form>
</body>
</html>
new-user.php
<?php include 'database.php';?>
<?php
mysqli_query($connect,"create table login(User_name varchar(50) NOT NULL,Password varchar(50) NOT NULL)");
$user_name=$_POST['user_name'];
$password=$_POST['password'];
if(empty($user_name)){
$name_error="name is required";
}
mysqli_query($connect,"Insert into login(User_name,Password) values('$user_name','$password')");
if(mysqli_affected_rows($connect)>0){
echo "<p>Credentials added</p>";
echo "<a href='index.html'>Go back</a>";
}else{
echo "<p>Error</p>";
echo mysqli_error($connect);
}
?>
database.php
<?php
$connect=mysqli_connect('localhost','root','','testdb');
if(mysqli_connect_errno($connect)){
echo 'failed to connect';
}
?>
上面没有在testdb数据库中创建任何表。也没有生成任何警报消息。但是,在单击“
http://localhost/try2/?user_name=aayushi&password=ded
”提交按钮后,Url发生了变化,但是之后什么也没有发生。这是我的第一个php代码,所以我真的不知道这到底是什么意思。 最佳答案
好的,因为似乎没有人真正在阅读您的代码,所以在将其放入PhpStorm之前,我遗漏了一些语法错误
将功能更改为此:
function submitForm(formId){
$.ajax({
url:'/new-user.php',
type:'POST',
data:{
user_name: $("#user_name").val(),
password: $("#password").val()
}
})
.complete(function (response) {
alert(response)
})
return false; // Prevents the form from submitting the standard way
}
编辑:将窗体更改为此:
<form onsubmit="return submitForm('#myForm');" id='myForm'>