将承诺绑定到函数
Binding a promise to a function
我一直在尝试向函数添加承诺,因此它会等待函数首先完成。我尝试过$.when
和.promise()
以及添加一个计数器和一个变量,当。map函数完成时更改,但我无法让checkInput()
函数完成并在if语句执行之前更改x, inputSmartCheck
和inputTNACheck
的值。因此,即使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
});
}
先来点基础知识…
我无法让checkInput()函数完成并更改x的值
x
在您的事件处理程序中定义,因此当您在checkInputs()
中引用它时,即使它在您的事件处理程序中称为,它也无法访问在事件处理程序范围内定义的变量,除非checkInputs
函数也要在该事件处理程序中定义。(我不建议在这种情况下这样做,这意味着每次事件处理程序运行时都要创建一个函数,这没什么大不了的,但仍然没有必要。)
在if语句执行之前
因为checkInputs()
做异步的事情,你不能仅仅依赖于调用它,而没有办法弄清楚它是否完成了。好消息是,你的承诺是正确的。
checkInputs
目前的工作方式,你永远不会知道是否所有的异步的东西在你的if
语句之前完成。让我们用一些基于checkInputs
函数的示例代码来解决这个问题。
function checkInputs() {
// an array to store the async calls
var asyncCalls = [];
// iterate over all the things
// changed to .each() because "each" is for iterating,
// and "map" is for returning a new array
$('.newStart').each(function() {
// get all your variables and stuff
var smartCheck = $.ajax({...});
var tnaCheck = $.ajax({...});
var asyncCallsPromise = $.when(smartCheck, tnaCheck).then(function() {
// do stuff
console.log(arguments);
});
asyncCalls.push(asyncCallsPromise);
});
// the important part, return a promise so you can check
// when checkInputs has processed all the things
return $.when.apply($, asyncCalls);
}
// somewhere else...
checkInputs().then(function() {
console.log('all the calls are done');
// here you can do the things that need to happen after checking the inputs
// e.g. the if statement.
});
希望这对正确的方向有帮助
相关文章:
- 如何向onClick事件处理程序传递一个接受参数的函数,并且仍然将该函数绑定到组件's”;这个“;上下文
- Jquery:将函数绑定到已绑定元素的点击事件
- 我可以通过使用函数绑定来保留默认值吗?如果没有,为什么
- 这在 Object 方法中不引用对象,而是引用函数绑定到的标记
- 为什么当我尝试将函数绑定到自身时,“this”对象仍然引用窗口
- 如何将函数绑定到使用链接函数创建 HTML 的角度指令
- 将jquery函数绑定到事件
- 将服务中的函数绑定到$scope(错误:无法设置undefined的属性'onChange')
- 使用闭包/函数绑定将自函数作为回调传递
- 如何在 Javascript 中将函数绑定到对象数据成员的更改
- 需要将内部函数绑定到元素的单击事件
- 在Javascript中将对象原型函数绑定到对象
- 将函数绑定到Twitter Bootstrap Modal Ajax Complete
- ng使用一个不识别临时变量形式ng repeat的函数绑定html
- 将函数绑定到baz后调用fn.apply(bar,[])
- 将函数绑定到采用参数的不同事件
- 如何将返回函数绑定到标记角度
- 在IE9中未检测到视图模型函数绑定,但在FF和Chrome中有效
- 如何将函数绑定到ShadowDOM内部的元素
- 将原型函数绑定到此的方式不那么冗长