私は関数に約束を追加しようとしていますので、関数が最初に完了するのを待つでしょう。 $.when
と.promise()
を試してみました。また、.map関数が完了したときに変更されたカウンタと変数を追加しましたが、ifステートメントの前にxのinputSmartCheck
とinputTNACheck
を完了して変更するためにcheckInput()
関数を取得できません実行します。このため、checkInput()
がxの値を1に変更しても、if文が実行される前に実行され、trueが返されます。私はJavascript
(私はjQuery
を好む)と少し経験がありますが、私は先進的な分野に取り組んでいると思います。どんな助けもありがとう。関数への約束のバインド
$(document).on("click", ".updateNewRows", function(){
$("#inputTNACheck").val("0"); //hidden inputs
$("#inputSmartCheck").val("0"); //hidden inputs
var x=0;
checkInput();
if(x==0 && $("#inputTNACheck").val()=="0" && $("#inputSmartCheck").val()=="0"){
$(".newStart").each(function() {
var get = $(this).closest(".newStart");
var data = {
empID:get.find(".tna_id").val(),
smart:get.find(".smart_uname").val(),
first:get.find(".f_name").val(),
last:get.find(".l_name").val(),
date:get.find(".start_date").val(),
type:get.find(".type").val()
};
$.post('new_user_process_bulk_create_records.php', data, function(data,textStatus) {
console.log(textStatus);
$("#newUsersTable").remove();
$(".updateNewRows").remove();
if ($("#returnUsersTable").html()) {
$("#newUsersRow").html('<div class="alert alert-success">Updated</div>');
}
else{
location.reload();
}
});
});
}
});
function checkInput(){
$('.newStart').map(function() {
var get = $(this).closest(".newStart");
var id = get.find(".tna_id");
var smart = get.find(".smart_uname");
var first = get.find(".f_name");
var last = get.find(".l_name");
var type = get.find(".type");
var smartCheck = $.ajax({
url: "new_user_validate_bulk_upload.php",
type: "POST",
data: {smart:smart.val(), type:'smart'},
success: function(data) {
if(data!="ok"){
$("#inputSmartCheck").val("1");
smart.css('background-color', 'pink');
}
else{smart.css('background-color', 'white');}
}
});
var tnaCheck = $.ajax({
url: "new_user_validate_bulk_upload.php",
type: "POST",
data: {tna:id.val(), type:'tna'},
success: function(data) {
if(data!="ok"){
$("#inputTNACheck").val("1");
id.css('background-color', 'pink');
}
else{id.css('background-color', 'white');}
}
});
$.when(smartCheck, tnaCheck).then(function() {
var name = new RegExp('^[a-zA-Z-]{0,20}$');
var smartID = new RegExp('^[a-zA-Z0-9]{0,10}$');
var empID = new RegExp('^[0-9]{0,10}$');
if (!name.test(first.val()) || first.val()=='') {
x=1;
first.css('border', '1px solid red');
}else{first.css('border', '1px solid #CCC');}
if (!name.test(last.val()) || last.val()=='') {
x=1;
last.css('border', '1px solid red');
}else{last.css('border', '1px solid #CCC');}
if(!smartID.test(smart.val()) || smart.val()==''){
x=1;
smart.css('border', '1px solid red');
}else{smart.css('border', '1px solid #CCC');}
if(!empID.test(id.val()) || id.val()==''){
x=1;
id.css('border', '1px solid red');
}else{id.css('border', '1px solid #CCC');}
if(type.val()==''){
x=1;
type.css('border', '1px solid red');
}else{type.css('border', '1px solid #CCC');}
});//$.when close
});
}