如何从本地存储中的数组中删除对象

时间:2020-08-06 20:42:12

标签: javascript html

我正在尝试通过识别笔记从本地存储中删除笔记 标题。我检查了w3schools和这个论坛的信息。我可以保存 数组,但是我无法删除特定的音符。

我尝试了,没有改变,这是我要实现的目标的一个例子,

这是删除之前的本地存储空间:

[{标题:“洗衣”,内容:“折叠衣服”},{标题:“库克”,内容: “购买食品”},{标题:“阅读”,内容:“去图书馆”}] 0:{标题: “洗衣”,内容:“折叠衣服”} 1:{标题:“烹饪”,内容:“购买” 食物”} 2:{标题:“阅读”,内容:“去图书馆”}

删除后我想要的输出:

[{标题:“洗衣”,内容:“折叠衣服”},{标题:“库克”,内容: “购买食物”}] 0:{标题:“洗衣”,内容:“折叠衣服”} 1:{标题: “烹饪”,内容:“购买食物”}

我希望能够根据其标题“已读”删除某项

const editNote = (e) => {
    saveContent.addEventListener('click', (e) => {
        e.preventDefault()
    
        let notes = []
        let note = {
            title: noteTitle.value,
            content: noteContent.value
        }

        // Parse the serialized data back into an aray of objects
        notes = JSON.parse(localStorage.getItem('items')) || [];
        // Push the new data (whether it be an object or anything else) onto the array
        notes.push(note);
       
        // Re-serialize the array back into a string and store it in localStorage
        localStorage.setItem('items', JSON.stringify(notes));
        // input.textContent = note.title 
    
        //remove notes by id
        const removeNote = () => {
            let title = noteTitle
            const index = notes.findIndex((note) => note.title === title)
    
            if (index > -1) {
                notes.splice(index,1);
            }
        }

        delNote.addEventListener('click', (e) => {
            removeNote()
            e.preventDefault()  

            // window.location.href='index.html'

        })

    })  

    
}

editNote()

3 个答案:

答案 0 :(得分:1)

更新数据后,您需要将项目设置到本地存储中

const removeNote = () => {
        let title = noteTitle
        const index = notes.findIndex((note) => note.title === title)
    
        if (index > -1) {
            notes.splice(index,1);
            localStorage.setItem('items', JSON.stringify(notes))
        }
    }

答案 1 :(得分:0)

localStorage.removeItem('ITEM TO REMOVE');

参考:https://developer.mozilla.org/en-US/docs/Web/API/Storage/removeItem

答案 2 :(得分:0)

我最终想通了。谢谢大家的答复和提供指导。

let input = document.querySelector('.input-bar')
let addItem = document.querySelector('.submit-btn')
let clearAll = document.querySelector('.clear-btn')


    // pay attension to indentation and ele location it will determine success

        addItem.addEventListener('click', (e) => {   
            e.preventDefault() 
            // Parse the serialized data back into an aray of objects
            items = JSON.parse(localStorage.getItem('items')) || [];    
            // Push the new data (whether it be an object or anything else) onto the array
            items.push(input.value);
            item = input.value
            // Re-serialize the array back into a string and store it in localStorage
            localStorage.setItem('items', JSON.stringify(items));
            

            var clear = document.createElement('button')
            clear.innerHTML= '<i class="fa fa-trash" style="font-size:20px ;color: #ac2412"></i>'
            let itemsEl = document.getElementById('items')
            let para = document.createElement("P");
            var t = document.createTextNode(`${input.value}`);
            para.appendChild(t);
            para.appendChild(clear)
            itemsEl.appendChild(para);
          
                
            input.value = ''



            clear.addEventListener('click', (e) => {
                itemsEl.removeChild(para)
                e.preventDefault()
                for (let index = 0; index < items.length; index++) {
                 if (items[index] === para.textContent) {
                    items.splice(index, 1)                
                    localStorage.setItem('items', JSON.stringify(items));
                  }                   
               }              
            })  

           
            
        })


        clearAll.addEventListener('click', (e) => {
            document.getElementById('items').innerHTML = ''
            localStorage.clear()
        })
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    color: white;
    background-color: black;
    margin: 40px 0px;
    text-align: center;
}

input {
    width: 300px;
    height: 46px;
    outline: none;
    background: transparent;
    border-color: silver;
    border-radius: 0;
    color: var(--mainWhite);
    font-size: 1.7rem;
}

h1 {
    margin: 20px 0px;
}

.submit-btn {
    margin: 0px 5px;
    width: 50px;
    height: 50px;
    outline: none;
    /* color: white; */
    background-color: rgb(21, 96, 194);
    color: white;
    font-size: 1.7rem;
}

.items-list {
    list-style-type: none;
}


li {
    display: inline-flex;
    border: 1px solid slategrey;
    font-size: 22px;
    margin: 20px 0px 0px 0px;
}

button {
    outline: none;
    margin: 0px 0px 0px 200px;
}

.clear-btn {
    width: 100px;
    height: 40px;
    margin: 30px;
    outline: none;
    background-color: rgb(21, 96, 194);
    color: white;
    font-size: 20px;
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="style.css">
    <script src="https://code.jquery.com/jquery-3.2.1.slim.min.js" integrity="sha384-KJ3o2DKtIkvYIK3UENzmM7KCkRr/rE9/Qpg6aAZGJwFDMVNA/GpGFF93hXpG5KkN" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js" integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q" crossorigin="anonymous"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js" integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl" crossorigin="anonymous"></script>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
    <title>Groceries</title>
</head>
<body>
    <h1>Grocery List</h1>
    <div>
       
        <input class="input-bar" type="text">
        <span>
            <button class="submit-btn">
                <i class="fa fa-pencil" aria-hidden="true"></i>
            </button>
        </span>
        <ul class="items-list" id="items"></ul>
    </div>
   <button class="clear-btn">Clear</button>
   
    <script src="index.js"></script>
</body>
</html>