2016-10-05 60 views
0

因此,我有一個帶有兩個單獨按鈕「編輯」和「停用」的表格。我能夠在停用和編輯時使用綁定功能,以便在添加行時使按鈕起作用。我也對大部分字段進行驗證。驗證在原始行上完美工作,但不適用於用戶添加的任何行。我怎樣才能解決這個問題?如何對新添加的表格行進行驗證

HTML/PHP:

<table id="html_master"> 
<thead> 
    <tr> 
    <td>ID</td> 
    <td>Vendor</td> 
    <td>Buyer ID</td> 
    <td>POC Name</td> 
    <td>POC Email</td> 
    <td>POC Phone</td> 
    <td>Edit/Delete</td> 
    </tr> 
</thead> 
<tbody> 

<?php 
    foreach ($dbh->query($sql) as $rows){ 
    ?> 
    <tr> 
     <td class="mr_id" contenteditable="false"><?php echo intval ($rows['MR_ID'])?></td> 
     <td class="mr_name" contenteditable="false"><?php echo $rows['MR_Name']?></td> 
     <td class="buyer_id" contenteditable="false"><?php echo $rows['Buyer_ID']?></td> 
     <td class="poc_n" contenteditable="false"><?php echo $rows['MR_POC_N']?></td>  
     <td class="poc_e" contenteditable="false"><?php echo $rows['MR_POC_E']?></td> 
     <td class="poc_p" contenteditable="false"><?php echo $rows['MR_POC_P']?></td> 
     <td><input type="button" class="edit" name="edit" value="Edit"> 
     <input type="button" class="deactivate" name="deactivate" value="Deactivate"></td> 
    </tr> 
<?php 
    } 
?> 
</tbody> 
     <br> 
     <input type="button" class="add" value="Add Row" onclick="addRow('html_master')"> 
</table> 

<input type="button" class="add" value="Add Row" onclick="addRow('html_master')"> 

</body> 
</html> 

的JavaScript:

// ----- Deactivate Row ----- 

function bindDeactivate() { 
    $('#html_master').on("click",".deactivate",function() { 
    var $this = $(this); 
    var $tr = $this.closest('tr'); 
    var action = $tr.hasClass('deactivated') ? 'activate' : 'deactivate'; 

    if (confirm('Are you sure you want to ' + action + ' this entry?')) { 
     $tr.toggleClass('deactivated'); 
     $this.val(function(i, t) { 
     return t == 'Deactivate' ? 'Activate' : 'Deactivate'; 
     }); 
    } 
    }); 
} 

$(document).ready(function() { 
    // Bind the deactivate button click to the function 
    bindDeactivate(); 
}); 

$(document).ready(function() { 
    // Bind the edit button click to the function 
    bindEdit(); 
}); 

// ----- Add Row ----- 

function addRow(tableID) { 

    var table = document.getElementById(tableID); 

    var rowCount = table.rows.length; 
    var row = table.insertRow(rowCount); 

    var cell1 = row.insertCell(0); 
    cell1.innerHTML = rowCount; 

    var cell2 = row.insertCell(1); 
    var element2 = document.createElement("input"); 
    element2.type = "text"; 
    element2.name = "txtbox[]"; 
    cell2.appendChild(element2); 

    var cell3 = row.insertCell(2); 
    var element3 = document.createElement("input"); 
    element3.type = "text"; 
    element3.name = "txtbox[]"; 
    cell3.appendChild(element3); 

    var cell4 = row.insertCell(3); 
    var element4 = document.createElement("input"); 
    element4.type = "text"; 
    element4.name = "txtbox[]"; 
    cell4.appendChild(element4); 

    var cell5 = row.insertCell(4); 
    var element5 = document.createElement("input"); 
    element5.type = "text"; 
    element5.name = "txtbox[]"; 
    cell5.appendChild(element5); 

    var cell6 = row.insertCell(5); 
    var element6 = document.createElement("input"); 
    element6.type = "text"; 
    element6.name = "txtbox[]"; 
    cell6.appendChild(element6); 

    var cell7 = row.insertCell(6); 
    var element7 = document.createElement("input"); 
    var element8 = document.createElement("input"); 
    element7.type = "button"; 
    element8.type = "button"; 
    element7.name="edit"; 
    element8.name="deactivate"; 

    var setClass = document.createAttribute("class"); 
    setClass.value = "edit"; 
    element7.setAttributeNode(setClass); 

    var setClass1 = document.createAttribute("class"); 
    setClass1.value = "deactivate"; 
    element8.setAttributeNode(setClass1); 

    element7.attr="class"; 
    element8.attr="class"; 
    element7.value="Edit"; 
    element8.value="Deactivate"; 
    cell7.appendChild(element7); 
    cell7.appendChild(element8); 

    // Bind this new deactivate button click to the function 
    $('#html_master').off("click",'.deactivate'); 
    bindDeactivate(); 

    // Bind this new deactivate button click to the function 
    $('#html_master').off("click",'.edit'); 
    bindEdit(); 
} 




function bindEdit() { 
    $('#html_master').on("click",".edit",function() { 
     var $this = $(this); 
     var tds = $this.closest('tr').find('td').not('.mr_id').filter(function() { 
     return $(this).find('.edit').length === 0; 
    }); 
    if ($this.val() === 'Edit') { 
     $this.val('Save'); 
     tds.prop('contenteditable', true); 
    } else { 
     var isValid = true; 
     var errors = ''; 
     $('#myDialogBox').empty(); 
     tds.each(function(){ 
      var type = $(this).attr('class'); 
      var value = $(this).text(); 
      switch(type){ 
       case "buyer_id": 
        if(!$.isNumeric(value)){ 
         isValid = false; 
         errors += "Please enter a valid Buyer ID\n"; 
         } 
        break; 
       case "poc_n": 
        if(value == value.match(/^[a-zA-Z\s]+$/)){ 
         break; 
        } 
        else { 
         isValid = false; 
         errors += "Please enter a valid Name\n"; 
        } 
        break; 
       case "poc_e": 
        if(value == value.match(/^[\w\-\.\+]+\@[a-zA-Z0-9\.\-]+\.[a-zA-z0-9]{2,4}$/)){ 
         break; 
        } 
        else { 
         isValid = false; 
         errors += "Please enter a valid Email\n"; 
        } 
        break; 
       case "poc_p": 
        if(value == value.match('^[0-9()+/-]{10,}$')){ 
         break; 
        } 
        else { 
         isValid = false; 
         errors += "Please enter a valid Phone Number\n";  
        } 
        break; 
      } 
     }) 
     if(isValid){ 
      $this.val('Edit');    // Modifed 
      tds.prop('contenteditable', false); 
     }else{ 
      alert(errors); 
     } 
    } 
}); 
} 
+0

whereis在你的問題中,「驗證在原始行上完美運行」?你如何驗證? – gaetanoM

+0

我的驗證是在javascript – Rataiczak24

+0

中的switch語句中,如果添加一行時,「保存」按鈕會首先顯示而不是「編輯」按鈕,這將會很不錯......它會最有意義,因爲您的添加信息那麼你想打保存....但這是第二優先權現在 – Rataiczak24

回答

1

對於新創建的DOM元素的方法給代表團是複雜的。我建議你簡化它:

$(document).on("click", "#html_master .deactivate", function() { 
$(document).on("click", "#html_master .edit", function() { 

這將避免混淆和減少行號:你不需要綁定 - 解除綁定綁定事件。

您在驗證過程中遇到的問題與您如何設置新元素有關。他們需要您在驗證中尋找的課程。因此,在您功能addRow(TABLEID){爲每個新的元素,你需要添加的類別,如:

element2.className = 'mr_name'; 

所以片段是:

// ----- Deactivate/Activate Row ----- 
 

 
$(document).on("click", "#html_master .deactivate", function() { 
 
    var $this = $(this); 
 
    var $tr = $this.closest('tr'); 
 
    var action = $tr.hasClass('deactivated') ? 'activate' : 'deactivate'; 
 

 
    // ------ Confirmation box in order to deactivate/activate row ----- 
 
    if (confirm('Are you sure you want to ' + action + ' this entry?')) { 
 
    $tr.toggleClass('deactivated'); 
 
    $this.val(function (i, t) { 
 
     return t == 'Deactivate' ? 'Activate' : 'Deactivate'; 
 
    }); 
 
    } 
 
}); 
 

 
// ----- Edit Row ----- 
 

 
$(document).on("click", "#html_master .edit", function() { 
 
    var $this = $(this); 
 
    var tds = $this.closest('tr').find('td').not('.mr_id').filter(function() { 
 
    return $(this).find('.edit').length === 0; 
 
    }); 
 
    if ($this.val() === 'Edit') { 
 
    $this.val('Save'); 
 
    tds.prop('contenteditable', true); 
 
    } else { 
 
    var isValid = true; 
 
    var errors = ''; 
 
    $('#myDialogBox').empty(); 
 
    // changed from here....... 
 
    var elements = tds; 
 
    if (tds.find('input').length > 0) { 
 
     elements = tds.find('input'); 
 
    } 
 
    elements.each(function (index, element) { 
 
     var type = $(this).attr('class'); 
 
     var value = (element.tagName == 'INPUT') ? $(this).val() : $(this).text(); 
 
     // changed from here....... to here 
 
     // ----- Switch statement that provides validation ----- 
 
     switch (type) { 
 
     case "buyer_id": 
 
      if (!$.isNumeric(value)) { 
 
      isValid = false; 
 
      errors += "Please enter a valid Buyer ID\n"; 
 
      } 
 
      break; 
 
     case "poc_n": 
 
      if (value == value.match(/^[a-zA-Z\s]+$/)) { 
 
      break; 
 
      } 
 
      else { 
 
      isValid = false; 
 
      errors += "Please enter a valid Name\n"; 
 
      } 
 
      break; 
 
     case "poc_e": 
 
      if (value == value.match(/^[\w\-\.\+]+\@[a-zA-Z0-9\.\-]+\.[a-zA-z0-9]{2,4}$/)) { 
 
      break; 
 
      } 
 
      else { 
 
      isValid = false; 
 
      errors += "Please enter a valid Email\n"; 
 
      } 
 
      break; 
 
     case "poc_p": 
 
      if (value == value.match('^[0-9()+/-]{10,}$')) { 
 
      break; 
 
      } 
 
      else { 
 
      isValid = false; 
 
      errors += "Please enter a valid Phone Number\n"; 
 
      } 
 
      break; 
 
     } 
 
    }) 
 
    if (isValid) { 
 
     $this.val('Edit'); 
 
     tds.prop('contenteditable', false); 
 
    } else { 
 
     alert(errors); 
 
    } 
 
    } 
 
}); 
 

 

 
// ----- Add Row ----- 
 

 
function addRow(tableID) { 
 

 
    var table = document.getElementById(tableID); 
 

 
    var rowCount = table.rows.length; 
 
    var row = table.insertRow(rowCount); 
 

 
    var cell1 = row.insertCell(0); 
 
    cell1.innerHTML = rowCount; 
 
    cell1.className = 'mr_id'; 
 

 
    var cell2 = row.insertCell(1); 
 
    var element2 = document.createElement("input"); 
 
    element2.type = "text"; 
 
    element2.name = "txtbox[]"; 
 
    element2.className = 'mr_name'; 
 
    cell2.appendChild(element2); 
 

 
    var cell3 = row.insertCell(2); 
 
    var element3 = document.createElement("input"); 
 
    element3.type = "text"; 
 
    element3.name = "txtbox[]"; 
 
    element3.className = 'buyer_id'; 
 
    cell3.appendChild(element3); 
 

 
    var cell4 = row.insertCell(3); 
 
    var element4 = document.createElement("input"); 
 
    element4.type = "text"; 
 
    element4.name = "txtbox[]"; 
 
    element4.className = 'poc_n'; 
 
    cell4.appendChild(element4); 
 

 
    var cell5 = row.insertCell(4); 
 
    var element5 = document.createElement("input"); 
 
    element5.type = "text"; 
 
    element5.name = "txtbox[]"; 
 
    element5.className = 'poc_e'; 
 
    cell5.appendChild(element5); 
 

 
    var cell6 = row.insertCell(5); 
 
    var element6 = document.createElement("input"); 
 
    element6.type = "text"; 
 
    element6.name = "txtbox[]"; 
 
    element6.className = 'poc_p'; 
 
    cell6.appendChild(element6); 
 

 
    var cell7 = row.insertCell(6); 
 
    var element7 = document.createElement("input"); 
 
    var element8 = document.createElement("input"); 
 
    element7.type = "button"; 
 
    element8.type = "button"; 
 
    element7.name = "edit"; 
 
    element8.name = "deactivate"; 
 

 
    var setClass = document.createAttribute("class"); 
 
    setClass.value = "edit"; 
 
    element7.setAttributeNode(setClass); 
 

 
    var setClass1 = document.createAttribute("class"); 
 
    setClass1.value = "deactivate"; 
 
    element8.setAttributeNode(setClass1); 
 

 
    element7.attr = "class"; 
 
    element8.attr = "class"; 
 
    element7.value = "Save"; 
 
    element8.value = "Deactivate"; 
 
    cell7.appendChild(element7); 
 
    cell7.appendChild(element8); 
 
}
table { 
 
    border-collapse: collapse; 
 
} 
 

 
td { 
 
    border: 1.5px solid black; 
 
    padding: 3px; 
 
} 
 

 
thead { 
 
    font-weight: bold; 
 
} 
 

 
.deactivated { 
 
    opacity: 0.5; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script> 
 

 

 
<table id="html_master"> 
 
    <thead> 
 
    <tr> 
 
     <td>ID</td> 
 
     <td>Vendor</td> 
 
     <td>Buyer ID</td> 
 
     <td>POC Name</td> 
 
     <td>POC Email</td> 
 
     <td>POC Phone</td> 
 
     <td>Edit/Delete</td> 
 
    </tr> 
 
    </thead> 
 
    <tbody> 
 

 
    <?php 
 
    foreach ($dbh->query($sql) as $rows){ 
 
    ?> 
 
    <tr> 
 
     <td class="mr_id" contenteditable="false"><?php echo intval ($rows['MR_ID'])?></td> 
 
     <td class="mr_name" contenteditable="false"><?php echo $rows['MR_Name']?></td> 
 
     <td class="buyer_id" contenteditable="false"><?php echo $rows['Buyer_ID']?></td> 
 
     <td class="poc_n" contenteditable="false"><?php echo $rows['MR_POC_N']?></td> 
 
     <td class="poc_e" contenteditable="false"><?php echo $rows['MR_POC_E']?></td> 
 
     <td class="poc_p" contenteditable="false"><?php echo $rows['MR_POC_P']?></td> 
 
     <td><input type="button" class="edit" name="edit" value="Edit"> 
 
      <input type="button" class="deactivate" name="deactivate" value="Deactivate"></td> 
 
    </tr> 
 
    <?php 
 
    } 
 
?> 
 
    </tbody> 
 
    <br> 
 
    <input type="button" class="add" value="Add Row" onclick="addRow('html_master')"> 
 
</table> 
 

 
<input type="button" class="add" value="Add Row" onclick="addRow('html_master')">

+0

這是很好的額外的行現在有驗證...但是,所有的原始行沒有任何驗證了 – Rataiczak24

+0

偉大的工程,謝謝! !有沒有辦法讓我添加一行時,它顯示保存與驗證,而不是先點擊編輯?它會更有意義......雖然我知道這與我原來的問題是分開的。 – Rataiczak24

+0

另外,你爲了未來的目的而改變了什麼? – Rataiczak24