Delete data from json array

后端 未结 3 1681
清歌不尽
清歌不尽 2021-02-15 00:29

I am trying to remove a piece of a data from a json array. For example I have this array

var favorites =    {
        \"userID\": \"12345678\",
        \"favorit         


        
相关标签:
3条回答
  • 2021-02-15 00:50

    To unset any variable use the delete statement:

    delete favorites.favorites[1].items[1]
    

    This is correct way, and it will work, but if your goal is to preserve indexes in order, then your way with the splice method is the way to go:

    favorites.favorites[1].items.splice(1,1);
    

    The above will remove one element (second parameter) starting at 1st index (first parameter).

    So to be clear: to remove the last element use this:

    var arr = favorites.favorites[1].items;
    arr.splice(arr.length - 1, 1);
    

    See your code on JsFiddle.

    You can take additional measures to protect the code in case the array is not set or empty:

    var arr = favorites.favorites[1].items;
    if ( arr && arr.length ) {
        arr.splice(arr.length - 1, 1);
    }
    
    0 讨论(0)
  • 2021-02-15 00:55

    If you want to actually remove an item from the array so that all items after it in the array move down to lower indexes, you would use something like this:

    favorites.favorites[1].items.splice(1, 1);
    

    You want to operate on the actual items array which means calling methods on the items array. For .splice(), you pass the index where you want to start modifying the array and then the number of items to remove thus .splice(1, 1) which will remove 1 item starting at index 1.

    0 讨论(0)
  • 2021-02-15 01:11

    I would most likely built a prototype method for this that makes the command a bit more simple to use

    // Place anywhere
    Object.prototype.cut = function(start, elements){
        return this.items.splice(start, elements);
    }
    
    // Call using this
    favorites.favorites[1].cut(1,1);
    

    This way you can extend methods and play around with the data in a very flexible way.

    == EDIT ==

    Maybe it was to flexible as Blue Skies pointed out. Updated example below. My style would be to add the favorites json to an object literal and include the methods you need in the literal. This example consists of the

    • JSON Data
    • a method to cut elements based on index
    • a method to get a favorite based on index
    • a method to return a favorite based on parameter name-value

    Snippet

    var favorites = {
        data: {
            "userID": "12345678",
            "favorites": [{
                "name": "My Favorites",
                "id": "87654321",
                "items": [{
                    "productID": "11234567",
                    "added": "TIMESTAMP",
                    "title": "Project",
                    "type": "Weekend Project",
                    "imageURL": "1"
                }, {
                    "productID": "11223456",
                    "added": "TIMESTAMP",
                    "title": "Bathroom",
                    "type": "Weekend Project",
                    "imageURL": "2"
                }, {
                    "productID": "11223345",
                    "added": "TIMESTAMP",
                    "title": "Curves",
                    "type": "Collections",
                    "imageURL": "3"
                }]
            }, {
                "name": "Bathroom",
                "id": "87654323",
                "items": [{
                    "productID": "11122224",
                    "added": "TIMESTAMP",
                    "title": "Project",
                    "type": "Weekend Project",
                    "imageURL": "1"
                }, {
                    "productID": "11122222",
                    "added": "TIMESTAMP",
                    "title": "Room",
                    "type": "Weekend Project",
                    "imageURL": "2"
                }, {
                    "productID": "11112222",
                    "added": "TIMESTAMP",
                    "title": "Strais",
                    "type": "Collections",
                    "imageURL": "3"
                },
    
                {
                    "productID": "11111222",
                    "added": "TIMESTAMP",
                    "title": "Door",
                    "type": "Collections",
                    "imageURL": "4"
                }]
            }]
        },
        cut: function(favorite, start, elements) {
            return this.data.favorites[favorite].items.splice(start, elements);
        },
        get: function(favorite) {
            return this.data.favorites[favorite];
        },
        find: function(value, param) {
            var found;
            this.data.favorites.filter(function(item, i) {
                if (item[param] === value) {
                    found = item;
                    return;
                };
            })
            return found;
        }
    };
    

    To use the find simply do something like this

    favorites.find("Bathroom", "name")
    
    0 讨论(0)
提交回复
热议问题