2011-10-28 139 views
0

我有这段代码,我删除了一些与我的问题无关的代码。两个循环混合

while ($row_pl = mysql_fetch_array($res_pl)) 
{ 
    // Uurtarief 
    $sql_uur = "SELECT 
       aantal_kop, 
       tarief_min, 
       tarief_max, 
       tijd_min, 
       tijd_max, 
       tijd_extra 
       FROM uurtarief 
       WHERE machine = '".$row_pl['machine']."' 
       ORDER BY aantal_kop ASC"; 

    if(!$res_uur = mysql_query($sql_uur)) 
    { 
     include('includes/errors/database_error.php'); 
    } 
    else 
    { 
     while ($row_uur = mysql_fetch_array($res_uur)) 
     { 
      ?> 
       <input type="text" name="tar_kop[]" size="8" value="<?php echo $row_uur['aantal_kop']; ?>" /> 
       <input type="text" name="tar_tarief[]" size="8" value="<?php echo $uurtarief; ?>" /> 
       <input type="text" name="tar_tijd_extra[]" size="8" value="<?php echo $row_uur['tijd_extra']; ?>" /> 
       <br /> 
      <?php 
     } 
    } 

    ?> 
<tr> 
    <td> 
     <input type="text" name="pl_aantal_kop[]" size="3" onChange="uur_tarief(this, <?php echo $i ?>)" value="" /> 
    </td> 
    <td> 
     <input type="text" name="pl_tarief_ph[]" size="4" value="" /> 
    </td> 
    </tr> 
<?php 
} 

用JavaScript我试图找到pl_aantal_kop[]的值,并发出相应的参数来pl_tarief_ph[]

function uur_tarief(selectVeld, nr) 
{ 
    if(document.getElementsByName('pl_aantal_kop[]')[nr].value == 1) 
    { 
     document.getElementsByName('pl_tarief_ph[]')[nr].value = document.getElementsByName('tar_tarief[]')[0].value; 
     document.getElementsByName('pl_snijtijd_extra[]')[nr].value = document.getElementsByName('tar_tijd_extra[]')[0].value; 
    } 

    if(document.getElementsByName('pl_aantal_kop[]')[nr].value == 2) 
    { 
     document.getElementsByName('pl_tarief_ph[]')[nr].value = document.getElementsByName('tar_tarief[]')[1].value; 
     document.getElementsByName('pl_snijtijd_extra[]')[nr].value = document.getElementsByName('tar_tijd_extra[]')[1].value; 
    } 

    if(document.getElementsByName('pl_aantal_kop[]')[nr].value == 3) 
    { 
     document.getElementsByName('pl_tarief_ph[]')[nr].value = document.getElementsByName('tar_tarief[]')[2].value; 
     document.getElementsByName('pl_snijtijd_extra[]')[nr].value = document.getElementsByName('tar_tijd_extra[]')[2].value; 
    } 

    if(document.getElementsByName('pl_aantal_kop[]')[nr].value == 4) 
    { 
     document.getElementsByName('pl_tarief_ph[]')[nr].value = document.getElementsByName('tar_tarief[]')[3].value; 
     document.getElementsByName('pl_snijtijd_extra[]')[nr].value = document.getElementsByName('tar_tijd_extra[]')[3].value; 
    } 

    if(document.getElementsByName('pl_aantal_kop[]')[nr].value == 5) 
    { 
     document.getElementsByName('pl_tarief_ph[]')[nr].value = document.getElementsByName('tar_tarief[]')[4].value; 
     document.getElementsByName('pl_snijtijd_extra[]')[nr].value = document.getElementsByName('tar_tijd_extra[]')[4].value; 
    } 

    if(document.getElementsByName('pl_aantal_kop[]')[nr].value == 6) 
    { 
     document.getElementsByName('pl_tarief_ph[]')[nr].value = document.getElementsByName('tar_tarief[]')[5].value; 
     document.getElementsByName('pl_snijtijd_extra[]')[nr].value = document.getElementsByName('tar_tijd_extra[]')[5].value; 
    } 
} 

发生是JavaScript保持开始计数的的第一行中的问题while ($row_uur = mysql_fetch_array($res_uur))循环而不是属于第一个循环的字段。在此循环的屏幕截图下方。

有什么建议吗?

enter image description here

回答

0

您可以将您的JS这样的:

function uur_tarief(selectVeld, nr) 
{ 
    var index = document.getElementsByName('pl_aantal_kop[]')[nr].value; 

    document.getElementsByName('pl_tarief_ph[]')[nr].value = document.getElementsByName('tar_tarief[]')[index - 1].value; 
    document.getElementsByName('pl_snijtijd_extra[]')[nr].value = document.getElementsByName('tar_tijd_extra[]')[index - 1].value; 
} 

你可以试试这个代码,并张贴回来?你在哪里初始化和调用JavaScript代码?你发布的代码看起来很好(虽然臃肿严重),所以它可能是其他地方的问题。

+0

什么值== 1,值== 2等声明?它们是代码的一部分。它们是可以在图像中发布的列中选择的数字。 – Muiter

+0

你的值总是比索引号大1,因此'[index - 1]'。 – Blender