代理模式

2017-04-02  本文已影响0人  卡卡卡卡颂

代理模式分类

  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);
  }
}

上一篇 下一篇

猜你喜欢

热点阅读