JavaScript设计模式与开发实践-代理模式

代理模式

代理模式的关键是,当客户不方便直接访问一个对象或者不满足需求时,提供一个替身对象来控制对这个对象的访问
,客户实际上时访问的是替身。
替身对象对请求作出一些处理之后,再把请求转给本体对象;

代理模式的基本用法

var Flower = function(){};

var xiaoming = {
    sendFlower : function (target) {
        target.receiveFlower(flower);
    }
};

var B  = {
    receiveFlower:function(flower) {
        A.listenGoodMood(function() {
            A.receiveFlower(flower)
        })
    }
};

var A = {
    receiveFlower:function(flower) {
        console.log('收到' + flower)
    },
    listenGoodMood:function(fn) {
        setTimeout(function() {
            fn();
        },10000)
    }
}

xiaoming.sendFlower(B);

使用虚拟代理实现图片预加载

虚拟代理把一些开销很大的对象,延迟到真正需要它的时候才去创建;

要符合单一职责原则,开发封闭远程
代理和本体接口的一致性

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('静态图片地址')
        img.src= src;
    }
})()

proxyImage('图片的线上地址!');

使用虚拟代理解决网络请求频繁问题

var synchronousFile =  function(id){
    console.log('开始执行网络请求');
}

var proxySynchronousFile = (function(){
    var cache = [];//保存要发的请求资源
    var timer = null;
    return function(id) {
        cache.push(id);
        if(timer) {
            return;
        }
        timer = setTimeout(function() {
            synchronousFile(cache.join(','))
            clearTimeout(timer)
            timer = null;
            cache.length = 0;
        },2000)
    }
})();

var checkbox = document.getElementsByTagName('input');
for (let i = 0; i < checkbox.length; i++) {
    checkbox[i].onclick = function() {
        if(this.checked === true) {
            proxySynchronousFile(this.id)
        }
    };
}

缓存代理

//mult符合单一职责原则(计算结果)
var mult = function() {
    var a = 1;
    for(var i = 0,l = arguments.length; i < l; i++) {
        a = a*arguments[i]
    }
    return a;
}

var proxyMult = (function()  {
    var cache = {};
    return function () {
        var agrs = Array.prototype.join.call(arguments,',');
        if(agrs in  cache) {
            return cache[agrs];
        }
        return cache[agrs] = mult.apply(this,arguments)
    }
    
})();
proxyMult(1,2,3,4)
proxyMult(1,2,3,4)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

绝对零度HCL

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值