0

Here I am creating array of submitted data and save it into html tables. but now I also want to delete single row of data from same array on button click how can i do this

Note : I want to delete it from array as well as from table

 var users = []
 $(document).ready(loadTable);
 function loadTable() {
 for(var i = 0; i < users.length; i++){
 for(var j = 0; j < users[i].length; j++){
 //console.log(users[i][j])
 }
 {continue;}
 }
 }
 $("#submit").on('click', function() {
 var temp = [document.getElementById("id").value,document.getElementById("name").value]
 users.push(temp)
 loadTable ($("tbody").append("<tr>" +
 "<td>" + $("#id").val() + "</td>" +
 "<td>" + $("#name").val() + "</td>" +
 
 "</tr>"));
 
 console.log(users)
 });
 
 table, th, td {
 border: 1px solid black;
 }
<html>
 <head>
 <title>Hello</title>
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
 </head>
 <body>
 <input type="text" name="id" id="id">
 <input type="text" name="name" id="name">
 <button type="button" id="submit">Add</button>
 <table id="demo">
 <tbody>
 </tbody>
 </table>
 </body>
</html>

asked Mar 31, 2022 at 18:02

1 Answer 1

1

Use a combination of array.pop() and element.remove() to remove last element in the array and table if exists.

var users = []
 $(document).ready(loadTable);
 function loadTable() {
 for(var i = 0; i < users.length; i++){
 for(var j = 0; j < users[i].length; j++){
 //console.log(users[i][j])
 }
 {continue;}
 }
 }
 $("#submit").on('click', function() {
 var temp = [document.getElementById("id").value,document.getElementById("name").value]
 users.push(temp)
 loadTable ($("tbody").append("<tr>" +
 "<td>" + $("#id").val() + "</td>" +
 "<td>" + $("#name").val() + "</td>" +
 
 "</tr>"));
 
 
 });
 $("#delete").on('click',function(){
 if(document.querySelectorAll('tbody > tr')){
 document.querySelectorAll('tbody > tr')[document.querySelectorAll('tbody > tr').length -1].remove();
 users.pop()
 console.log(users)
 }
 
 })
table, th, td {
 border: 1px solid black;
 }
<html>
 <head>
 <title>Hello</title>
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
 </head>
 <body>
 <input type="text" name="id" id="id">
 <input type="text" name="name" id="name">
 <button type="button" id="submit">Add</button>
 <button type='button' id='delete'>Delete</button>
 <table id="demo">
 <tbody>
 </tbody>
 </table>
 </body>
</html>

answered Mar 31, 2022 at 18:09
Sign up to request clarification or add additional context in comments.

1 Comment

Its only removing last array value but I want to show delete option on every button and need to delete any index value from array

Your Answer

Draft saved
Draft discarded

Sign up or log in

Sign up using Google
Sign up using Email and Password

Post as a guest

Required, but never shown

Post as a guest

Required, but never shown

By clicking "Post Your Answer", you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.