2011-10-28 327 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