美文网首页
设计模式:代理模式

设计模式:代理模式

作者: San十二 | 来源:发表于2018-11-21 23:51 被阅读0次

代理模式

代理模式是为一个对象提供一个代用品或占位符,以便控制对它的访问。

简单点讲,就是我们被希望直接通过操作A对象的,但是直接操作太复杂了,我们希望对A对象的操作少一点,这个时候就可以使用代理模式,生成一个代理对象,把部分操作放在这个代理对象上实现。

书中举的例子是图片预加载,我们就拿这个预加载说话好了。

图片预加载

假设我们要往网页中插入一个图片节点,我们本打算这么写。

var setMyImageSrc = (function () {
  var img = document.createElement('img');
  document.body.appendChild(img);

  return function (src) {
    img.src = src;
  }
})();

setMyImageSrc('....jpg');

现在我们希望图片在加载的过程中呢,先显示一张占位图;当图片加载结束后呢,我们再替换这张图片。

代理模式的思路是这样:如果我们想要对一个对象添加功能;但是这个对象自身的功能是非常完备的;我们可以通过代理模式,添加一个代理对象,在不改动原对象的情况下,添加我们想要的功能。

在这里就是,我们需要添加一个setProxyImageSrc方法,来对setMyImageSrc添加一个预加载的功能。

var setProxyImageSrc = (function () {
  var loadingIcon = '...';
  setMyImageSrc(loadingIcon);

  var img = new Image();
  img.onload = function () {
    setMyImageSrc(img.src);
  }

  return function (src) {
    img.src = src;
  }
})();

setProxyImageSrc('jpg');

这样,在不修改setMyImageSrc源码的情况下,我们通过增加一个setProxyImageSrc的代理,就成功添加了预加载的功能。

这就是代理模式。如果谁谁谁说现在不需要这个预加载的功能了,那我们只需要去掉这一层代理就可以了;增添功能还是很方便的。

收集请求

假如有很多个checkbox,每个checkbox点击的时候都会发出一个请求,过多的点击产生的过多的请求必然会对服务器产生压力。

按照代理模式的方式,我们先给出一个基本的情景。

<div id="form">
  <input type="checkbox" id="1">
  <input type="checkbox" id="2">
  <input type="checkbox" id="3">
  <input type="checkbox" id="4">
  <input type="checkbox" id="5">
  <input type="checkbox" id="6">
  <input type="checkbox" id="7">
  <input type="checkbox" id="8">
</div>
    var form = document.getElementById('form');
    form.onclick = function (e) {
      var o = e.target;
      if (o.type === 'checkbox' && o.checked) {
        haveSomeOp(o.id);
      }
    }

    var haveSomeOp = function (id) {
      console.log(id);
    }

现在我们有个需求,就是希望收集这些请求,不要立即发出;而是到达了一个周期时间后我们再一起发出。

    var proxySomeOp = (function () {
      var cache = [];
      var timer = null;
      
      return function (id) {
        cache.push(id);
        if (!timer) {
          timer = setTimeout(function () {
            haveSomeOp(cache.join(','));
            cache = [];
            timer = null;
          }, 1000);
        }
      }
    })();

然后我们将#form的点击事件修改为proxySomeOp就好啦。

相关文章

  • Mybatis代理设计模式(Proxy)与编程实现原理

    最易懂设计模式解析适配器设计模式模板方法设计模式Mybatis多级代理 1. 认识代理模式 1.1 模式定义 给某...

  • 模板方法设计模式(Template Method)

    最易懂设计模式解析适配器设计模式Mybatis代理设计模式Mybatis多级代理 1. 认识模板方法模式 1.1 ...

  • 适配器设计模式(Adapter)

    最易懂设计模式解析模板方法设计模式Mybatis代理设计模式Mybatis多级代理 1. 认识适配器模式 1.1 ...

  • 理解java的代理模式和动态代理

    代理模式 代理模式是23种设计模式之一,属于结构型模式。代理模式是最常见也是最常用的模式之一,只不过有很多设计模式...

  • spring框架中的设计模式二

    在这篇文章中,介绍4种设计模式。结构型设计模式:代理和复合模式。行为型设计模式:策略和模板方法模式。 代理模式 面...

  • 10、结构型模式-代理设计模式

    1、加盟商来啦-你需要掌握的代理设计模式 简介:讲解代理设计模式,让代理帮你完成工作 代理设计模式(Proxy P...

  • 设计模式之代理模式

    设计模式之代理模式 10分钟看懂动态代理设计模式(升级篇)-对这篇动态代理模式的思路整理 仿JDK实现动态代理逻辑...

  • 动态代理原理解析

    注:源自于Android 一、代理模式 代理模式是java23种设计模式常用的一种设计模式。代理模式是客户端不直接...

  • 设计模式

    常用的设计模式有,单例设计模式、观察者设计模式、工厂设计模式、装饰设计模式、代理设计模式,模板设计模式等等。 单例...

  • 前端设计模式

    JS设计模式一:工厂模式jS设计模式二:单例模式JS设计模式三:模块模式JS设计模式四:代理模式JS设计模式五:职...

网友评论

      本文标题:设计模式:代理模式

      本文链接:https://www.haomeiwen.com/subject/syqkqqtx.html