私は次のHTMLコードを持っています:
<form action="view_rebate_master.php" method="post">
<div class="form-group">
<label for="company_name" class="col-lg-12">Manufacturer</label>
<div class="col-lg-12">
<select id="company_id" class="form-control" onchange="GetProductByManufacturerID(this.value)" name="company_id">
<option selected="selected" value="">All Manufacturers</option>
<option value="40">Test</option>
<option value="42">RK</option>
<option value="49">Blue Nun</option>
<option value="58">Unique Imports</option>
<option value="59">Pernod Ricard</option>
<option value="77">Smoking Loon</option>
<option value="78">Beringer</option>
</select>
</div>
</div>
<div class="col-xs-4">
<div class="form-group">
<label for="product_id" class="col-lg-12">Product Name</label>
<div class="col-lg-12">
<select id="product_id" class="form-control" name="product_id">
<option selected="selected" value="">All Products</option>
<option value="12">Riesling</option>
<option value="24">Superio Vodka</option>
<option value="32">Heineken</option>
<option value="33">Strong Bow</option>
<option value="34">Grocery</option>
<option value="35">Ruler</option>
<option value="36">Glass</option>
<option value="37">Brown Bread</option>
<option value="38">White Bread</option>
<option value="55">Cabernet Sauvignon</option>
</select>
</div>
</div>
</div>
<div class="col-lg-12">
<div class="col-xs-5">
<div class="form-group">
<button type="submit" class="btn btn-primary" name="search" id="search">Search Rebates</button>
</div>
</div>
</div>
AJAX jQueryコードは次のとおりです。
function GetProductByManufacturerID(value) {
$.ajax({
type: "POST",
url: "add_rebate_by_quat_volume.php",
data: { manufacturer_id: value, op:"" },
beforeSend: function() {
$("#product_id").html('<option> Loading ...</option>');
},
success:function(data){
$("#product_id").html('');
$("#product_id").append(data);
}
});
}
AJAX関数呼び出しがselectcontrol(メーカー選択用のselect control)の値を変更して行われた場合、送信ボタンを無効にしたいので、AJAX成功応答を受信します。AJAX成功応答を受信すると、ユーザーは送信ボタンをクリックできるはずです。これを実現するにはどうすればよいですか?よろしくお願いします。
for disable
$("#search").prop('disabled', true);
for enable
$("#search").prop('disabled', false);
あなたの関数で以下のように
function GetProductByManufacturerID(value) {
$.ajax({
type: "POST",
url: "add_rebate_by_quat_volume.php",
data: { manufacturer_id: value, op:"" },
beforeSend: function() {
$("#product_id").html('<option> Loading ...</option>');
$("#search").prop('disabled', true); // disable button
},
success:function(data){
$("#product_id").html('');
$("#product_id").append(data);
$("#search").prop('disabled', false); // enable button
}
});
}
このような何かがあなたが望むことをするでしょう。これは、ページ全体で、ajaxリクエストに対してグローバルです。
$(document).ajaxStart(function() {
$("#search").prop('disabled', true);
}).ajaxStop(function() {
$("#search").prop('disabled', false);
});
Ajax呼び出しの前にボタンを無効にし、コールバックが成功したときに再び有効にします。以下のような何かを行う際に問題はありますか?
function GetProductByManufacturerID(value) {
$('#search').addAttr('disabled');
$.ajax({
type: "POST",
url: "add_rebate_by_quat_volume.php",
data: { manufacturer_id: value, op:"" },
beforeSend: function() {
$("#product_id").html('<option> Loading ... </option>');
},
success:function(data){
$("#product_id").html('');
$("#product_id").append(data);
$('#search').removeAttr('disabled');
}
});
}