循环中的javascript连续条件

javascript successive conditions in a loop

本文关键字:连续 条件 javascript 循环      更新时间:2023-09-26

我有一个javascript函数。第三个条件不起作用,它在循环中单独起作用,但在其他条件下不起作用。我不知道为什么。有人能帮忙吗??

function verif(ref1, ref2, ref3, ref4, ref5, ref6) {
    document.forms["form"].intitule.value = ref1;
    document.forms["form"].montant.value = ref2;
    document.getElementById(ref3).selected = true;
    for (var i = 1; i <= 400; i++) {
        if (document.getElementById("newDay").options[i].text == ref4) {
            document.getElementById("newDay").options[i].selected = true;
        }
        if (document.getElementById("newMonth").options[i].text == ref5) {
            document.getElementById("newMonth").options[i].selected = true;
        }
        if (document.getElementById("newYear").options[i].text == ref6) {
            document.getElementById("newYear").options[i].selected = true;
        }
    }
}

将每个条件添加到自己的try-catch中,看看是否有任何条件抛出错误。我添加了警报来帮助您调试。

function verif(ref1, ref2, ref3, ref4, ref5, ref6) {
    document.forms["form"].intitule.value = ref1;
    document.forms["form"].montant.value = ref2;
    document.getElementById(ref3).selected = true;
    for (var i = 1; i <= 400; i++) {
        try{
        if (document.getElementById("newDay").options[i].text == ref4) {
            document.getElementById("newDay").options[i].selected = true;
        }
        }catch(err){
          alert(err);
        }
        try{
        if (document.getElementById("newMonth").options[i].text == ref5) {
            document.getElementById("newMonth").options[i].selected = true;
        }
        }catch(err){
          alert(err);
        }
        try
        {
        if (document.getElementById("newYear").options[i].text == ref6) {
            document.getElementById("newYear").options[i].selected = true;
        }
        }catch(err){
          alert(err);
        }
    }
}

看起来您正试图为所有3项执行一个循环。这样做的好处是所需迭代次数较低,但您没有包含任何代码,以确保您不会试图查找未定义的<option>s。接下来,考虑使用一个循环的好处是如何真正节省迭代次数,因此有两个循环,第二个循环从第一个循环结束的地方开始,仍然具有最小的迭代次数。

因此,如果您想保存循环迭代,您可以尝试这样的方法,其中循环中的项目会根据i的距离和已经找到的内容而减少。不过,这确实会导致一些代码重复。注意循环是如何按的顺序排序的,因为12<31<x(我假设x20个月,当然这是不存在的。

function verif(ref1, ref2, ref3, ref4, ref5, ref6) {
    document.forms["form"].intitule.value = ref1;
    document.forms["form"].montant.value = ref2;
    document.getElementById(ref3).selected = true;
    var i = 0, found = {day: 0, month: 0, year: 0},
        elm = {
            days: document.getElementById("newDay"),
            months: document.getElementById("newMonth"),
            years: document.getElementById("newYear")
        };
    // months length = min(days, months, years)
    while (++i < elm.months.length && !found.months) {
        if (elm.days.options[i].text == ref4) {
            found.days = elm.days.options[i].selected = true;
        }
        if (elm.months.options[i].text == ref5) {
            found.months = elm.months.options[i].selected = true;
        }
        if (elm.years.options[i].text == ref6) {
            found.years = elm.years.options[i].selected = true;
        }
    }
    // days length = min(days, years)
    while (++i < elm.days.length && !found.days) {
        if (elm.days.options[i].text == ref4) {
            found.days = elm.days.options[i].selected = true;
        }
        if (elm.years.options[i].text == ref6) {
            found.years = elm.years.options[i].selected = true;
        }
    }
    // only years left
    while (++i < elm.years.length && !found.years) {
        if (elm.years.options[i].text == ref6) {
            found.years = elm.years.options[i].selected = true;
        }
    }
}

您可能还注意到,我没有包含任何break语句,这是因为如果我们在以后的循环中找到了仍将要查找的内容,我们仍然希望搜索特定于当前循环的项,我们不希望跳过同一迭代的其他检查,也不想在以后的环路上浪费时间。因此,一段与break执行类似操作的代码位于<condition>中。