代理模式

代理模式分类

  1. 保护代理
    控制不同权限对象对目标对象对访问。
  2. 虚拟代理
    把一些开销很大对对象延迟到真正需要他对时候才去创建。下面用虚拟代理实现图片预加载:
var myImage=(function() {
  var imgNode=document.createNode('img');
  document.body.appendChild(imgNode);
  
  return {
      setSrc: function(src) {
        imgNode.src=src;
      }
  }
})()

var proxyImage=(function() {
  var img=new Image;
  img.onload=function() {
    myImage.setSrc(this.src);
  }
  return {
      setSrc: function(src) {
        myImage.setSrc('file://loading.jpg');
        img.src=src;
      }
  }
})()

proxyImage.setSrc('src.jpg');

设计原则

  1. 用户可以放心的请求代理,只关心能否得到想要的结果。
  2. 在任何使用本体的地方都可以替换成使用代理。

缓存代理

//用代理模式实现缓存

//先实现一个目标函数 这里是求阶乘
var mult=function() {
  console.log('开始计算阶乘');
  var a=1;
  for (var i=0,cur=arguments[i];i<arguments.length;i++) {
      a=a*cur;
  }
  console.log('输出:',a);
  return a;
}

//缓存结果的代理 调用代理即可
var proxyMult=(function() {
  var cache={};
  return function() {
    var args=Array.prototype.join.call(arguments,',');
    if (args in cache) {
        console.log('输出:',cache[args]);
        return cache[args];
    }
    return (cache[args]=mult.apply(this,arguments));
  }
})()


//这里我们可以更进一步,创建一个 缓存代理的工厂,就可以接受不同的运算规则了
var createProxyfactory=function(fn) {
  var cache={};
  return function() {
    var args=Array.prototype.join.call(arguments,',');
    if (args in cache) {
        return cache[args];
    }
    return cache[args]=fn.apply(this,arguments);
  }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容