代理模式

2015-06-09  本文已影响30人  JohnSmith

定義

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

要點

核心代碼

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);
    };
};
上一篇 下一篇

猜你喜欢

热点阅读