jQuery « дождаться окончания each
/**
* GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann
* (http://qbnz.com/highlighter/ and http://geshi.org/)
*/
.javascript.geshi_code {font-family:monospace;}
.javascript.geshi_code .imp {font-weight: bold; color: red;}
.javascript.geshi_code .kw1 {color: #000066; font-weight: bold;}
.javascript.geshi_code .kw2 {color: #003366; font-weight: bold;}
.javascript.geshi_code .kw3 {color: #000066;}
.javascript.geshi_code .co1 {color: #006600; font-style: italic;}
.javascript.geshi_code .co2 {color: #009966; font-style: italic;}
.javascript.geshi_code .coMULTI {color: #006600; font-style: italic;}
.javascript.geshi_code .es0 {color: #000099; font-weight: bold;}
.javascript.geshi_code .br0 {color: #009900;}
.javascript.geshi_code .sy0 {color: #339933;}
.javascript.geshi_code .st0 {color: #3366CC;}
.javascript.geshi_code .nu0 {color: #CC0000;}
.javascript.geshi_code .me1 {color: #660066;}
.javascript.geshi_code span.xtra { display:block; }
$("fieldset").each(function(){
if($(this).attr("id")!="_main")
{
var addon = $(this).attr("id");
$("#"+addon+" input").each(function(){
if($(this).val().length < 1)
{
$(this).removeClass("valid").removeClass("invalid").addClass("invalid");
$(this).parent().find("span").remove();
$(this).parent().find("p").remove();
$(this).parent().append("<span class="invalid-side-note">"+getTranslate("users", "js_addErrorMain")+"</span>");
return false;
}
else
{
$(this).removeClass("valid").removeClass("invalid").addClass("valid");
$(this).parent().find("span").remove();
$(this).parent().find("p").remove();
$(this).parent().append("<span class="valid-side-note">"+getTranslate("users", "js_addNoError")+"</span>");
}
});
}
});
как дождаться выполнения этого участка кода, что бы дальше скрипт не обрабатывался до завершения цикла, так как если хоть одно значение не удовлетворяет условию, скрипт должен остановиться.
$("fieldset").each(function(){
if($(this).attr("id")!="_main")
{
var addon = $(this).attr("id");
$("#"+addon+" input").each(function(){
if($(this).val().length < 1)
{
$(this).removeClass("valid").removeClass("invalid").addClass("invalid");
$(this).parent().find("span").remove();
$(this).parent().find("p").remove();
$(this).parent().append("<span class="invalid-side-note">"+getTranslate("users", "js_addErrorMain")+"</span>");
return false;
}
else
{
$(this).removeClass("valid").removeClass("invalid").addClass("valid");
$(this).parent().find("span").remove();
$(this).parent().find("p").remove();
$(this).parent().append("<span class="valid-side-note">"+getTranslate("users", "js_addNoError")+"</span>");
}
});
}
});
как дождаться выполнения этого участка кода, что бы дальше скрипт не обрабатывался до завершения цикла, так как если хоть одно значение не удовлетворяет условию, скрипт должен остановиться.
1 ответов
на текущий момент исправил проблему так:
var countedinp = 0;
var status = "start";
var allinp = $("fieldset[id!='_main'] input[type='text']").length;
$("fieldset").each(function(){
if($(this).attr("id")!="_main")
{
var addon = $(this).attr("id");
$("#"+addon+" input").each(function(){
if($(this).val().length < 1)
{
$(this).removeClass("valid").removeClass("invalid").addClass("invalid");
$(this).parent().find("span").remove();
$(this).parent().find("p").remove();
$(this).parent().append("<span class=\"invalid-side-note\">"+getTranslate("users", "js_addErrorMain")+"</span>");
status = "stop";
}
else
{
$(this).removeClass("valid").removeClass("invalid").addClass("valid");
$(this).parent().find("span").remove();
$(this).parent().find("p").remove();
$(this).parent().append("<span class=\"valid-side-note\">"+getTranslate("users", "js_addNoError")+"</span>");
countedinp++;
}
});
}
});
while(countedinp != allinp)
{
if(status == "stop") return false;
}
но это криво, хотелось бы как то покрасивее выполнить задачу
Специально для таких целей в jQuery с версии 1.5 ввели объект deferred