将数组添加到本地存储并检索该数组

时间:2015-03-09 04:23:46

标签: javascript local-storage

我正在使用本地存储,我遇到了一个问题。

我想像这样存储密钥的值。这些值是动态添加的,应以“,”分隔。我应该通过比较值

来检索它们

这是我的观点

key                                       value
user1                                   a,b,c,d,e....

应该动态添加值字段中的值。说我有字段用户名并添加好友。用户名应该取位置键,添加好友(动态)应取值位置。

first iteration:
username _a________
add friend _hello_______

localstorage : key                   value
                a                     hello
second iteration:

username _____a___
add friend : __stact___

local storage : key            value
                a              hello , stact
third iteration : 
username _____a___
add friend : __hi___

local storage : key            value
                a              hello , stact,hi

如果我想删除stact,我必须写localStorage.removeKey(a[1])

请帮助我,因为我是这个东西的新手 我在下面的代码中使用了其中一个答案,但它没有用。相反,它抛出错误 我试过以下

var ls = (function () {
    var _key = function (username) {
        return username; 
    },
    _saveFriends = function (username, friends) {
        localStorage.setItem(ls._key(username), JSON.stringify(friends));
    };

    function getFriends(username) {
        return JSON.parse(localStorage.getItem(ls._key(username)) || '[]');
    }

    return {
        getFriends: getFriends,
        addFriend: function (username, friend) {
            var friends = getFriends(username);
            friends.push(friend);
            _saveFriends(friends);
        },
        removeFriend: function (username, friend) {
            var friends = getFriends(username);
            var index = friends.indexOf(friend);
            if (index >= 0) {
                friends.splice(index, 1);
            }
            _saveFriends(friends);
        }
    };
})();

function main()
{
ls.addFriend('revanth','aastha');
ls.addFriend('revanth','pobala');
ls.getFriends('revanth');

这是错误  未捕获的TypeError:undefined不是函数,错误在此行中 return JSON.parse(localStorage.getItem(ls._key(username)));

2 个答案:

答案 0 :(得分:0)

function addItem(user,str){
  // get value in localStorage and split into array
  var tempArr = localStorage.getItem(user).split(",");
  // if only adding unique items, check if unique
  // if (tempArr.indexOf(str)<0)...
  tempArr.push(str);
  // turn the temp array back into string
  var newStr = tempArr.join();
  // save back to localStorage
  localStorage.setItem(user, newStr);
}

答案 1 :(得分:0)

以下是您可以在全局命名空间中使用的一些函数,以便在任何框架中轻松完成此任务:

var ls = (function () {
    var _key = function (username) {
        return username; // in case you want to namespace the keys later
    },
    _saveFriends = function (username, friends) {
        localStorage.setItem(ls._key(username), JSON.stringify(friends));
    };

    function getFriends(username) {
        return JSON.parse(localStorage.getItem(ls._key(username)) || '[]');
    }

    return {
        getFriends: getFriends,
        addFriend: function (username, friend) {
            var friends = getFriends(username);
            friends.push(friend);
            _saveFriends(friends);
        },
        removeFriend: function (username, friend) {
            var friends = getFriends(username);
            var index = friends.indexOf(friend);
            if (index >= 0) {
                friends.splice(index, 1);
            }
            _saveFriends(friends);
        }
    };
})();

// Use like so: 
//   ls.getFriends(username); 
//   ls.addFriend(username, friendname); 
//   ls.removeFriend(username, friendname);