首页 > 解决方案 > 验证仅适用于第一行,不适用于其他行!我觉得这是因为返回真/假,但我需要在我的验证

问题描述

HTML PHP

<td align="center"><input type="text" class="form-control" id="<?php echo $i;?>" name="r2<?php echo $i+1;?>" onblur="mvalidate2()" style="text-align: center; border: 1px solid #ccc;width: 46px;">
        <label id="errora<?php echo $i;?>" style="font-size:13px; color:#cc0000;margin-left: 5px;"><div style = "font-size:13px; color:#cc0000;"></div></label></td>  

//我得到一个错误 Uncaught TypeError: Cannot read property 'value' of null at mvalidate2

JAVASCRIPT

function mvalidate2(){
 var count = <?php echo $count2;?>;
  for(var i=0;i<count;i++){
    var sr = document.getElementById(i).value;
    var temp  = 'errora';
    var t = temp.concat(i);

    if(sr<5){
     document.getElementById(t).innerHTML=" ";
     return true;
     }
    else{
     document.getElementById(t).innerHTML=" Enter valid Rating out of 4 ";
     return false;
     }
   }
 } 

标签: javascriptphphtmlarraysvalidation

解决方案


您不必在 JavaScript 中按数字开头 ID

    var sr = document.getElementById("inp"+i).value;
<input type="text" class="form-control" id="inp<?php echo $i;?>" name="r2<?php echo $i+1;?>" onblur="mvalidate2()" style="text-align: center; border: 1px solid #ccc;width: 46px;">

function mvalidate2(){
 var count = <?php echo $count2;?>;
  for(var i=0;i<count;i++){
    var temp  = 'errora';
    var t = temp.concat(i);

    if(sr<5){
     document.getElementById(t).innerHTML=" ";
     return true;
     }
    else{
     document.getElementById(t).innerHTML=" Enter valid Rating out of 4 ";
     return false;
     }
   }
 } 


推荐阅读