0

我尝试了有意义的方法:

在下面的模块中localStorage.foo有效,但localStorage.session_array['privacy']返回未定义。

这是现代浏览器的原型代码。

var ISession = ( function () 
{

    localStorage.session_array = 
    {
        privacy:            0
    };

    localStorage.foo = 1; 

    var SessionI = function ( ) 
    {
    };

    SessionI.prototype.get = function( type ) 
    {
        return localStorage.session_array[ type ];
    };

    SessionI.prototype.set = function( type, value ) 
    {
        localStorage.session_array[ type ] = value;
        alert( '|' + localStorage.foo ); // returns 1
        alert( '|' + localStorage.session_array[ 'privacy' ] ); // returns undefined
    };

    return SessionI;

} ) ();

同时,我将使用非数组属性来实现它。

4

2 回答 2

3

localStorage only saves data as strings

于 2012-06-05T18:31:50.363 回答
1

由于并非所有浏览器都支持 localstorage,因此您可能需要查看store.js。它在可用时支持本地存储,如果不支持,则使用其他一些存储机制(globalStorage 和 UserData)。最好的部分是您还可以存储 JSON 编码的数据。

// Store 'marcus' at 'username'
store.set('username', 'marcus')

// Get 'username'
store.get('username')

// Remove 'username'
store.remove('username')

// Clear all keys
store.clear()

// Store an object literal - store.js uses JSON.stringify under the hood
store.set('user', { name: 'marcus', likes: 'javascript' })

// Get the stored object - store.js uses JSON.parse under the hood
var user = store.get('user')
alert(user.name + ' likes ' + user.likes)

store.set('user', { name: 'marcus', likes: 'javascript' })
alert("Hi my name is " + store.get('user').name + "!")

store.set('tags', ['javascript', 'localStorage', 'store.js'])
alert("We've got " + store.get('tags').length + " tags here")
于 2012-06-05T18:32:45.973 回答