Как очистить конкретный объект JSON в массиве JSON в localStorage с помощью кнопки удаления? - PullRequest
0 голосов
/ 13 октября 2018

У меня есть программа, которая просто добавляет учеников в таблицу и сохраняет эту информацию в локальном хранилище.Я могу добавить учеников и увидеть данные, хранящиеся в локальном хранилище, но моя большая проблема - выяснить, как удалить конкретный объект из локального хранилища при нажатии кнопки после добавления (без очистки всего локального хранилища).

Ссылка для теста: https://www.chriscaldwelldev.com/studentIA/student.html

Вот таблица и входные данные (HTML):

<body>

    <div class="container">

        <h1 class="title">Student Manager</h1>

        <div class="controlCenter">
            <table id="studentTable" class="table">
                <thead>
                    <tr>
                        <th>Student Number:</th>
                        <th>Name:</th>
                        <th>Address:</th>
                        <th>Phone Number:</th>
                        <th>GPA:</th>
                        <th>Academic Plan:</th>
                        <th>Level:</th>
                        <th>Status:</th>
                    </tr>
                </thead>
                <tbody id="students"></tbody>
                <tbody>
                    <tr>
                        <td><input type="text" id="studentN"></td>
                        <td><input type="text" id="name"></td>
                        <td><input type="text" id="address"></td>
                        <td><input type="text" id="phoneN"></td>
                        <td><input type="text" id="gpa"></td>
                        <td><input type="text" id="ap"></td>
                        <td><select id="selectL" name="SelectL">
                            <option value="" disabled selected>Select...</option>
                            <option value="freshman">Freshman</option>
                            <option value="sophomore">Sophomore</option>
                            <option value="junior">Junior</option>
                            <option value="senior">Senior</option>
                            <option value="graduate">Graduate</option>
                        </select></td>
                        <td><select id="selectS" name="SelectS">
                            <option value="" disabled selected>Select...</option>
                            <option value="active">Active</option>
                            <option value="inactive">Inactive</option>
                        </select></td>
                    </tr>
                </tbody>
            </table>

            <input id="add" class="addButton" value="ADD">

        </div>

    </div>

</body>

ВотJS:

// when the document loads
            $(function(){

                // add an onclick function to the id=add button 
                $("#add").click(function(){

                    var studentN = $("#studentN").val();
                    var name = $("#name").val();
                    var address = $("#address").val();
                    var phoneN = $("#phoneN").val();
                    var gpa = $("#gpa").val();
                    var ap = $("#ap").val();
                    var selectL = $("#selectL").val();
                    var selectS = $("#selectS").val();

                    if(studentN==null || name==null || address==null || phoneN==null || 
                        gpa==null || ap==null || selectL==null || selectS==null){
                        alert("All Fields Are Required to Add a Student");
                        return;
                    }

                    //create JSON object with text inputs with key:value pairs
                    var student = {
                        studentN: studentN,
                        name: name,
                        address: address,
                        phoneN: phoneN,
                        gpa: gpa,
                        ap: ap,
                        selectL: selectL,
                        selectS: selectS
                    }

                    //load local storage
                    var students = JSON.parse(localStorage.getItem("students"));

                    //if empty
                    if(!students){
                        students = [];   
                    }

                    students.push(student);

                    localStorage.setItem("students", JSON.stringify(students));

                    // store a copy of the row in the body
                    var row = $("<tr>");

                    // store a copy of the current state in the <td> tag  
                    var studentNData = $("<td>");
                    // now change the innerHTML for that <td> 
                    studentNData.html(studentN);
                    // append the new value to our row
                    row.append(studentNData);

                    (...)

                    // store a copy of the current state for the next <td> tag
                    var selectSData = $("<td>");
                    // change the inner html of the <td>
                    selectSData.html(selectS);
                    // append the new value to our row
                    row.append(selectSData);

                    var deleteButton = $("<td>" + "<input type=\"button\" class=\"deleteButton\" value=\"X\">");
                    row.append(deleteButton);

                    // on the DOM, put the new row on the top of the list
                    $("#students").prepend(row);

                    // reset the values of the text inputs to empty strings 
                    $("#studentN").val("");
                    $("#name").val("");
                    $("#address").val("");
                    $("#phoneN").val("");
                    $("#gpa").val("");
                    $("#ap").val("");
                    $("#selectL").val("");
                    $("#selectS").val("");


                });

                var students = JSON.parse(localStorage.getItem("students"));

                $("#studentTable").on('click', '.deleteButton', function () {
                    $(this).closest('tr').remove();
                    //I can't think of what to do here...

                });

                if (students) {

                    // loop through the entire JSON array stored in local storage
                    for (i in students) {

                        // get a current copy of the content in the row
                        var row = $("<tr>");

                        // store a copy of the current state in the <td> tag, update the innerHTML, then append it to the DOM at the end of the row
                        var studentNData = $("<td>");
                        studentNData.html(students[i].studentN);
                        row.append(studentNData);

                        (...)

                        var selectSData = $("<td>");
                        selectSData.html(students[i].selectS);
                        row.append(selectSData);

                        var deleteButton = $("<td>" + "<input type=\"button\" class=\"deleteButton\" value=\"X\">");
                        row.append(deleteButton);

                        // now add the row to the DOM at the beginning of the list
                        $("#students").prepend(row);
                    }

                }

});

Я предполагаю, что все, что мне нужно сделать, в первую очередь должно быть сделано в клике deleteButton.Я продумал некоторые идеи, но они кажутся супер неправильными.Я ценю любую помощь, если вы можете.

1 Ответ

0 голосов
/ 13 октября 2018

Одним из решений, которое вы можете использовать, является добавление атрибута data-studentn к вашим кнопкам удаления.Затем, когда нажата кнопка удаления, вы можете загрузить массив студентов из localStorage, удалить студента с этим студентом и сохранить новый массив студентов.

Изменить

"<input type=\"button\" class=\"deleteButton\" value=\"X\">"

до

"<input type=\"button\" class=\"deleteButton\" value=\"X\" data-studentn=\"" + students[i].studentN + "\" >"

Примечание: не забудьте сделать нечто подобное в другом месте, где вы создаете кнопку удаления.

Под //I can't think of what to do here... вы можетевыполните следующие действия:

var deletedStudentN = $(this).attr('data-studentn');
var students = JSON.parse(localStorage.getItem("students"));
students = students.filter(function(student) {
    return student.studentN != deletedStudentN;
});
localStorage.setItem("students", JSON.stringify(students));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...