分析jq中缓存的案例

本文通过对jQuery-1.11.1.js源码的分析,揭示了jQuery如何实现数据缓存。通过一个简单的代码案例,阐述了缓存的本质——键值对结构,并利用JavaScript闭包保护缓存数据。同时,讨论了在缓存数据达到一定规模时,如何进行数据清理。最后,对原有的缓存函数进行了优化,使读取更加便捷。尽管有所简化,但仍然体现出jQuery缓存设计的巧妙。
摘要由CSDN通过智能技术生成

分析jq中缓存的案例

jQuery流行框架在程序界还是非常火的,下面我们通过扒开jquery-1.11.1.js 的源码,来分析它是如何实现一些数据缓存的。

下面就是jQuery里头的createCache的源码,

/**
 * Create key-value caches of limited size
 * @returns {Function(string, Object)} Returns the Object data after storing it on itself with
 *  property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)
 *  deleting the oldest entry
 */
function createCache() {
    var keys = [];

    function cache( key, value ) {
        // Use (key + " ") to avoid collision with native prototype properties (see Issue #157)
        if ( keys.push( key + " " ) > Expr.cacheLength ) {
            // Only keep the most recent entries
            delete cache[ keys.shift() ];
        }
        return (cache[ key + " " ] = value);
    }
    return cache;
}

一时间是不是看的有点晕呢?我试着从最基本的代码案例来推演出这个案例,毕竟这个缓存案例还是非常精炼的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值