开源中国

我们不支持 IE 10 及以下版本浏览器

It appears you’re using an unsupported browser

为了获得更好的浏览体验,我们强烈建议您使用较新版本的 Chrome、 Firefox、 Safari 等,或者升级到最新版本的IE浏览器。 如果您使用的是 IE 11 或以上版本,请关闭“兼容性视图”。
StorageLRU首页、文档和下载 - LRU 缓存实现 - 开源中国社区
Float_left Icon_close
全部项目分类
我要评价
BSD
JavaScript 查看源码»
跨平台
Yahoo
分享
收藏
收录时间:2015-05-08
StorageLRU 详细介绍

StorageLRU(storage-lru) 是 LRU 缓存实现,可以用在本地存储或者其他存储机制,支持一个类似的接口。

注意:这个库是使用 CommonJS 风格编写的,如果要在浏览器使用,需要使用 BrowserifyWebpack 类似的工具。

主要特性:

  • 可插拔的离线存储

  • 统计数据

  • 自定义的 PurgeComparator

  • 优先级

  • 自动清理

使用:

var StorageLRU = require('storage-lru').StorageLRU;
var asyncify = require('storage-lru').asyncify;
var lru = new StorageLRU(asyncify(localStorage), {
    purgeFactor: 0.5,  // this controls amount of extra space to purge.
    purgedFn: function (purgedKeys) {
        console.log('These keys were purged:', purgedKeys);
    }
});
console.log(lru.numItems()); // output 0, assuming the storage is clear
lru.setItem('foo', 'bar', {}, function (err) {
    if (err) {
        // something went wrong. Item not saved.
        console.log('Failed to save item: err=', err);
    }
});
lru.setItem('fooJSON', {foo: 'bar'}, {json: true}, function (err) {
    if (err) {
        // something went wrong. Item not saved.
        console.log('Failed to save item: err=', err);
    }
});
lru.getItem('foo', {json: false}, function (err, value) {
    if (err) {
        // something went wrong, for example, can't deserialize
        console.log('Failed to fetch item: err=', err);
        return;
    }
    console.log('The value of "foo" is: ', value);
});
lru.removeItem('foo', function (err) {
    if (err) {
        // something went wrong. Item not removed.
    }
});
var stats = lru.stats();
StorageLRU

选择将代码托管在码云
你还在等什么

可能是中国最大最好的代码托管平台


大家对 StorageLRU 的评论 (全部 0 条评论)
{{repayCom.userName}}
StorageLRU 相关博客
顶部