js 设计模式 第八章 Bridge Pattern

场景 1  事件处理

是页面上,我们往往用到事件绑定。这这个例子中,我们对元素添加click 事件处理,在handle 函数中,通过得到元素的id属性,进行ajax操作。

addEvent(element, 'click', getBeerById);
function getBeerById(e) {
        var id = this.id;
        asyncRequest('GET', 'beer.uri?id=' + id, function(resp) {
            // Callback response.
            console.log('Requested Beer: ' + resp.responseText);
        });
}

这个绑定函数有几个问题:

  • 因为改函数需要e这个事件变量,所以这个函数只能运行在浏览器的环境中,这样不能简单的测试这个函数的正确性
  • 这个函数的输入参数是e,而里面的实现根本就不需要这个变量
一个更好的方法是,写一个独立的函数
function getBeerById(id, callback) {
    // Make request for beer by ID, then return the beer data.
    asyncRequest('GET', 'beer.uri?id=' + id, function(resp) {
    // callback response
        callback(resp.responseText);
    });
}
好处:
  • 函数的输入参数是id,更符合逻辑
  • callback 方法更通用。任何充服务器取得的数据,通过callback得到,并进行下一步的处理。
  • program to interface ,not an implementation
  • 可以在单元测试中测试
最后,上面的事件绑定实现方式如下:
addEvent(element, 'click', getBeerByIdBridge);
function getBeerByIdBridge (e) {
    getBeerById(this.id, function(beer) {
        console.log('Requested Beer: '+beer);
     });
}
有了这个桥接函数,我们就可以在任何地方测试getBeerById这个核心函数

场景2      类的私有属性
通过类的特权方法,访问类的私有属性,这个特权方法,就是私有属性通向外边的桥
var Public = function() {
		var secret = 3;
		this.privilegedGetter = function() {
		    return secret;
		};
};
var o = new Public;
var data = o.privilegedGetter();



xiong:已为接口编程,而非实现编程为指导,通过桥来链接抽象的接口和实现。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值