美文网首页
代理模式

代理模式

作者: JohnSmith | 来源:发表于2015-06-09 11:42 被阅读30次

定義

為一個對象提供一個代用品或佔位符,以便控制對它的訪問。

要點

  • 代理模式的關鍵是,當客戶不方便直接訪問一個對象或者不滿足需要的時候,提供一個替身對象來控制對這個對象的訪問,客戶實際上訪問的是替身對象。替身對象對請求做出一些處理之後,再把請求轉交給本體對象。
  • 代理模式包括許多小分類,在 JavaScript 開發中最常用的是虛擬代理和緩存代理。
  • 虛擬代理:把一些開銷很大的對象,延遲到真正需要它的時候才去創建。使用場景包括圖片預加載等。
  • 緩存代理:為一些開銷大的運算結果提供暫時的存儲,在下次運算時,如果傳遞進來的參數跟之前一致,則可以直接返回之前存儲的運算結果。
  • 代理和本體接口的一致性:這樣代理接手請求的過程對於用戶來說是透明的,用戶並不清楚代理和本體的區別。任何使用本體的地方都可以替換成使用代理。
  • 在JavaScript中,如果代理對象和本體對象都是一個函數,函數必然都能被執行,則可以認為它們也具有一致的接口。

核心代碼

var myImage = (function() {
    var imgNode = document.createElement('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('/loading.gif');
            img.src = src;
        }
    };
})(); 

proxyImage.setSrc('http://.../image.jpg');
\\ 代理對象和本體對象都是函數
var myImage = (function() {
    var imgNode = document.createElement('img');
    document.body.appendChild(imgNode);
    return function(src) {
        imgNode.src = src;
    };
})();

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

proxyImage('http://.../image.jpg');
\\ 用高階函數創建緩存代理的工廠
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);
    };
};

相关文章

  • 设计模式

    单例模式 模板方法模式 工厂模式 代理模式 静态代理 JDK动态代理

  • 设计模式

    单例模式 代理模式 静态代理 jdk动态代理 cglib动态代理 工厂模式 适配器模式 建造者模式 观察者模式

  • kube-proxy的3种模式

    userspace代理模式 iptables代理模式 IPVS代理模式 https://kubernetes.io...

  • 第4章 结构型模式-代理模式

    一、代理模式简介 二、代理模式3个角色 三、代理模式的优点 四、代理模式的实例(游戏代练)

  • 理解代理模式

    原创博客地址 简介 代理模式,也叫做委托模式,分为:静态代理动态代理 代理模式也是平时比较常用的设计模式之一,代理...

  • 结构型 代理模式(文末有项目连接)

    1:什么是代理模式 2:没用代理模式时的实例 3:使用代理模式将其解耦(静态代理) 3:使用代理模式将其解耦(动态...

  • 设计模式-动态代理模式

    之前介绍了代理模式,大家也都了解了代理模式,不过之前介绍的代理模式是静态代理,静态代理什么意思?静态代理指的是代理...

  • 代理模式

    一、什么是代理模式 代理模式(Proxy pattern):代理模式又叫委托模式,是为某个对象提供一个代理对象,并...

  • 设计模式之代理模式(Proxy模式)

    代理模式的引入 代理模式的实例程序 代理模式的分析 代理模式的引入 Proxy是代理人的意思,指的是代替别人进行工...

  • Java设计模式之代理模式

    Java设计模式之代理模式 代理模式 静态代理 动态代理 为什么需要代理 通过代理,我们能够不用知道委托人是谁,而...

网友评论

      本文标题:代理模式

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