Лично я без колебаний создаю функции, которые обрабатывают весь объект, в вашем случае что-то вроде:
var blob = [{"id":"item-1","href":"google.com","icon":"google.com"},
{"id":"item-2","href":"youtube.com","icon":"youtube.com"},
{"id":"item-3","href":"google.com","icon":"google.com"},
{"id":"item-4","href":"google.com","icon":"google.com"},
{"id":"item-5","href":"youtube.com","icon":"youtube.com"},
{"id":"item-6","href":"asos.com","icon":"asos.com"},
{"id":"item-7","href":"google.com","icon":"google.com"},
{"id":"item-8","href":"mcdonalds.com","icon":"mcdonalds.com"}];
// define helper functions
Storage.prototype.setBlob = function (blob)
{
for (i in blob) {
// example of storageObjet: {'item-3': {'href': 'google.com', 'icon': 'google.png'}}
var struct={};
for (key in blob[i]) {
if (key != 'id') {
struct[key] = blob[i][key];
}
};
this.setObject(blob[i].id, struct);
}
}
Storage.prototype.setObject = function(key, obj) {
this.setItem( key, JSON.stringify(obj) );
};
Storage.prototype.getObject = function(key) {
return JSON.parse(this.getItem(key));
};
// do stuff
sessionStorage.clear();
sessionStorage.setBlob(blob);
var key = 'item-6';
var item = sessionStorage.getObject(key);
item.href = 'stackoverflow.com';
sessionStorage.setObject(key, item);
for (key in sessionStorage) {
if (typeof(sessionStorage[key]) == 'string') {
var item2 = sessionStorage.getObject(key);
$('#stuff').append( $('<div>').html(item2.href) );
}
}
проверьте этот jsfiddle
NB: в этом примере я использую sessionStorage вместо localStorage, но интерфейс тот же, оба используют прототип Storage.
Как видите, я изменяю структуру каждого элемента примерно так: {'item-3': {'href': 'google.com', 'icon': 'google.png'}}. Я делаю это, потому что это лучше отражает javascript, localStorage и общую концепцию ключ/значение и значительно упрощает использование.
в этом примере у вас есть:
var item = sessionStorage.getObject(key);
item.href = 'stackoverflow.com';
sessionStorage.setObject(key, item);
это выглядит очень практичным способом обработки localStorage для меня.
Более того, функция setBlob может обрабатывать случайное и переменное количество элементов на элемент. Это позволяет вам иметь один элемент с 5 атрибутами, если вы хотите, в то время как все остальные имеют 2. Он работает с вашей «плоской» структурой, пока есть один элемент, вызываемый с ключом «id».
РЕДАКТИРОВАТЬ: отлажено и переключено на более классический setValue(key, item);
person
roselan
schedule
12.11.2011