私は、データがmysqlデータベースに挿入され、データベースの行数が実行され、その結果が表示されるフォームページに返されるサーバー側ページにデータをポストするフォームを持っています。Ajaxリクエストを遅らせる方法は?
私はajaxを使用して行数データを取得していますが、データがデータベースに挿入されるまでAjax呼び出しを遅延させることが可能かどうかはわかりません。データが送信されましたか?現在のコードは動作しますが、フォームが送信される前の行数だけが表示されます。私は真の結果を得るためにページをリロードする必要があります。
Form.php
<form class="form-inline" action="" id="myform" form="" method="post">
<!-- Text input-->
<div class="form-group">
<label class="col-md-4 control-label" for="name"></label>
<div class="col-md-8">
<input id="name" name="name" type="text" placeholder="name" class="form-control input-lg" required>
</div>
</div>
<!-- Button -->
<div class="form-group">
<label class="col-md-4 control-label" for="submit1"></label>
<div class="col-md-4">
<button id="submitButtonId" name="submit1" class="btn btn-primary btn-xl">Submit</button>
</div>
</div>
</form>
<div id="count"></div>
</div>
jqueryの
<script>
//Post data from form
$(document).ready(function(){
$("#submitButtonId").on("click",function(e){
e.preventDefault();
var formdata = $(this.form).serialize();
$.post('server.php', formdata,
function(data){
//Reset Form
$('#myform')[0].reset();
});
return false;
});
});
</script>
<script>
//Fetch Rowcount from server.php
$(document).ready(function(){
$.ajax({
url: 'data.php',
dataType: "json",
success: function (data) {
$("#count").html(data.count);
}
});
});
</script>
server.phpという
<?php
//Connect to db
include_once("db_conx.php");
if(isset($_POST['name'])){
$name= mysqli_real_escape_string($db_conx,$_POST['name']);
//Update Database
$stmt = $db_conx->prepare('INSERT INTO myTable set name=?');
$stmt->bind_param('s',$name);
$stmt->execute();
}
//Count Rows
$sql="SELECT name FROM myTable";
$query = mysqli_query($db_conx, $sql);
// Return the number of rows in result set
$rowcount=mysqli_num_rows($query);
// send output
$my_data=array(count=>"$rowcount");
echo json_encode($my_data,true);
?>
成功関数内別のAJAXを追加... – santosh
私が正しく理解していれば、あなたはまだ、より多くのデータが挿入されたときに行数がページのロード時にフェッチが、リフレッシュされるようにしたいですか? – apokryfos