Javascript写一个缓存代理(AOP)

Posted .Neter

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Javascript写一个缓存代理(AOP)相关的知识,希望对你有一定的参考价值。

自己写了一个缓存代理,使用代理模式,支持指定函数、支持按参数缓存,原创

后续会支持缓存异步数据

CacheProxy:

function CacheProxy(obj,proxyMethods){
        var _cache={};
        var _getType=Object.prototype.toString;  
        var _this = this;
        var _getCacheName=function(methodName,args){
            var caches = [];
            caches.push(methodName);
            for (var i = 0,len=args.length; i <len; i++) {
                caches.push(args[i]);
            }
            return caches.join(_);
        };
        if (_getType.apply(obj)!=="[object Object]") {
            console.info("parameter obj must be object");
            return;
        }
        if (_getType.apply(proxyMethods)!=="[object Array]") {
            if (proxyMethods===undefined ) {
                proxyMethods=[];
            }
            else{
                console.info("parameter proxyMethods must be Array");
                return;                
            }
        }

        for(attr in obj){
            if(_getType.apply(obj[attr])==="[object Function]"){
                (function(attr){
                   _this[attr]=function(){
                    if (proxyMethods.length===0 || proxyMethods.indexOf(attr)>-1) {
                        var cacheName = _getCacheName(attr,_this[attr].arguments);
                        if (_cache[cacheName]!==undefined) {
                            return _cache[cacheName]+"_cache";
                        }
                        _cache[cacheName] = obj[attr].apply(_this,arguments);
                        return _cache[cacheName];
                    }
                    
                    return obj[attr].apply(_this,arguments);
                }; 
            })(attr);
                
            }
        }

客户端:

    function Person(){
        this.sayName=function(a,b,c){
            return "fan";
        };
        this.sayHello=function(a,b){
            return "Hello";
        };
    }

var p = new Person();
var cacheProxy = new CacheProxy(p,["sayName","sayHello"]);//第二个参数可以不写
console.info(cacheProxy.sayName());
console.info(cacheProxy.sayName("1"));
console.info(cacheProxy.sayName("1","2"));
console.info(cacheProxy.sayName("1","2"));
console.info(cacheProxy.sayName("1"));
console.info(cacheProxy.sayName("1"));
 
console.info(cacheProxy.sayHello());
console.info(cacheProxy.sayHello("1"));
console.info(cacheProxy.sayHello("1","2"));
console.info(cacheProxy.sayHello("1","2"));

 

以上是关于Javascript写一个缓存代理(AOP)的主要内容,如果未能解决你的问题,请参考以下文章

再话AOP,从简化缓存操作说起

spring-AOP原理

AOP-代理拦截实现Redis缓存

AOP-代理拦截实现Redis缓存

AOP-代理拦截实现Redis缓存

spring aop