桥接模式定义:桥梁模式的用意是"将抽象化(Abstraction)与实现化(Implementation)脱耦,使得二者可以独立地变化"。这句话有三个关键词,也就是抽象化、实现化和脱耦。

最简单的桥接模式例子:事件监听器

addEvent(element,"click",getResultByIdBridge);
function getResultByIdBridge(e){
getById(this.id, function(result){
//TODO: this is operate result
});
}

桥接模式复杂例子:构建XHR连接队列

 var asyncRequest = (function(){

     function handleReadyState(o,callback){
var poll = window.setInterval(function(){
if(o && o.readyState ==4){
window.clearInterval(poll);
if(callback) callback(o);
}
},50);
} var getXHR = function(){
var http;
try{
http = new XMLHttpRequest();
getXHR = function(){
return new XMLHttpRequest();
};
}catch(e){
var msxml = ["MSXML2.XMLHTTP.3.0","MSXML2.XMLHTTP","Microsoft.XMLHTTP"];
for(var i =0, len = msxml.length;i <len;i++){
try{
http = new ActiveXObject(msxml[i]);
getXHR = function(){
return new ActiveXObject(msxml[i]);
};
break;
}catch(e){}
}
}
return http;
} return function(method,url,callback,postData){
var http = getXHR();
console.log("send url is:" + url);
http.open(method,url,true);
handleReadyState(http,callback);
http.send(postData || null);
}
})(); Function.prototype.method = function(name,fn){
this.prototype[name] = fn;
return this;
} if(!Array.prototype.forEach){
Array.method("forEach",function(fn,thisObj){
var scope = thisObj || window;
for(var i = 0, len = this.length;i<len;i++){
fn.call(scope,this[i],i,this);
}
})
} if(!Array.prototype.filter){
Array.method("filter",function(fn,thisObj){
var scope = thisObj || window;
var a = [];
for(var i = 0 , len = this.length;i<len;i++){
if(fn.call(scope,this[i],i,this)){
a.push(this[i]);
}
}
return a;
})
} /******************************************/
window.DED = window.DED || {};
DED.util = DED.util || {};
DED.util.Observer = function(){
this.fns = [];
}
DED.util.Observer.prototype = {
subscribe:function(fn){ //签署
this.fns.push(fn);
},
unsubscribe:function(fn){
this.fns = this.fns.filter(function(item){
if(item != fn){
return item;
}
});
},
fire:function(o){
this.fns.forEach(function(item){
item(o);
});
}
} DED.Queue = function(){
this.queue = [];
this.onComplete = new DED.util.Observer();
this.onFailure = new DED.util.Observer();
this.onFlush = new DED.util.Observer(); this.retryCount = 3;
this.currentRetry = 0;
this.paused = false;
this.timeout = 5000;
this.conn = {};
this.timer = {};
}; DED.Queue.method("flush",function(){
if(!this.queue.length >0){
return ;
}
if(this.paused){
this.paused = false;
return;
} var that = this;
this.currentRetry++;
var abort = function(){
that.conn.abort();
if(that.currentRetry == that.retryCount){
that.onFailure.fire();
that.currentRetry = 0;
}else{
that.flush();
}
}; this.timer = window.setTimeout(abort,this.timeout);
var callback = function(o){
window.clearTimeout(that.timer);
that.currentRetry = 0;
that.queue.shift();
that.onFlush.fire(o.responseText);
if(that.queue.length == 0){
that.onComplete.fire();
return;
}
that.flush();
}; this.conn = asyncRequest(this.queue[0]["method"],this.queue[0]["url"],callback,this.queue[0]["params"]);
}).
method("setRetryCount",function(count){
this.retryCount = count;
}).
method("setTimeout",function(time){
this.timeout = time;
}).
method("add",function(o){
this.queue.push(o);
}).
method("pause",function(){
this.paused = true;
}).
method("dequeue",function(){
this.queue.pop();
}).
method("clear",function(){
this.queue = [];
});

对应的html

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
body{font:100% georgia,times,serif}
h1,h2{font-weight: normal;}
#queue-items{height:1.5rem;}
#add-stuff{padding:0.5rem; background:#ddd; border:1px solid #bbb;}
#result-area{padding:0.5rem; border: 1px solid #bbb;}
</style>
</head>
<body id="exmapl">
<div id="doc">
<h1>Ajax Conection Queue</h1>
<div id="queue-items"></div>
<div id="add-stuff">
<h2>Add Requests to Queue</h2>
<ul id="adders">
<li><a href="#" id="action-01">add 01 to Queue</a></li>
<li><a href="#" id="action-02">add 02 to Queue</a></li>
<li><a href="#" id="action-03">add 03 to Queue</a></li>
<li><a href="#" id="action-04">add 04 to Queue</a></li>
</ul>
</div>
<h2>oTther Queue actions</h2>
<ul id="items">
<li><a href="#" id="flush">Flush</a></li>
<li><a href="#" id="dequeue">dequeue</a></li>
<li><a href="#" id="pause">pause</a></li>
<li><a href="#" id="clear">clear</a></li>
</ul> <div id="result-area">
<h2>Results:</h2>
<div id="results"></div>
</div>
</div>
</body>
</html>
<script type="text/javascript" src="Bridge.js"></script>
<script>
window.onload = function(){
var q = new DED.Queue();
q.setRetryCount(5);
q.setTimeout(3000); var items = document.getElementById("items");
var queue = document.getElementById("queue-items");
var requests = [];
q.onFlush.subscribe(function(data){
results.innerHTML = data;
requests.shift();
queue.innerHTML = requests.toString();
});
q.onFailure.subscribe(function(){
results.innerHTML += "<span style='color:red;'>Connection error</span>";
}); q.onComplete.subscribe(function(){
results.innerHTML += "<span style='color:green;'>Completed!</span>";
}); var actionDispatcher = function(element){
switch(element){
case "flush":
q.flush();
break;
case "dequeue":
requests.pop();
queue.innerHTML = requests.toString();
break;
case "pause":
q.pause();
break;
case "clear":
q.clear();
requests = [];
queue.innerHTML = "";
break;
}
}; var addRequest = function(request){
var data = request.split("-")[1];
q.add({
method:"GET",
url:"http://127.0.0.1:8020/WS_WEB/JS%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F/js/ajax.json?data=" + data,
params:null
});
requests.push(data);
queue.innerHTML = requests.toString();
}; items.onclick = function(e){
var e = e || window.event;
var src = e.target || e.srcElement;
try{
e.preventDefault();
}catch(e){
e.returnValue = false;
}
if(src.id){
actionDispatcher(src.id);
}
}; var adders = document.getElementById("adders");
adders.onclick = function(){
var e = e || window.event;
var src = e.target || e.srcElement;
if(e.preventDefault){
e.preventDefault();
}else{
e.returnValue = false;
}
if(src.id)addRequest(src.id);
} } </script>

js设计模式-桥接模式的更多相关文章

  1. 转:设计模式-----桥接模式(Bridge Pattern)

    转自:http://www.cnblogs.com/houleixx/archive/2008/02/23/1078877.html 记得看原始链接的评论. 学习设计模式也有一段时间了,今天就把我整理 ...

  2. 跟着ZHONGHuan学习设计模式--桥接模式

    转载请注明出处! ! !http://blog.csdn.net/zhonghuan1992 全部配套代码均在github上:https://github.com/ZHONGHuanGit/Desig ...

  3. linkin大话设计模式--桥接模式

    linkin大话设计模式--桥接模式 桥接模式是一种结构化模式,他主要应对的是:由于实际的需要,某个类具有2个或者2个以上维度的变化,如果只是使用继承将无法实现功能,或者会使得设计变得相当的臃肿.我们 ...

  4. java设计模式——桥接模式

    一. 定义与类型 定义:将抽象部分与他的具体实现部分分离,使它们都可以独立的变化,通过组合的方式建立两个类之间的联系,而不是继承 类型:结构性. 二. 使用场景 (1) 抽象和具体实现之间增加更多的灵 ...

  5. 【设计模式】Java设计模式 - 桥接模式

    [设计模式]Java设计模式 - 桥接模式 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 原创作品,更多关注我CSDN: 一个有梦有戏的人 准备将博客园.CSDN一起 ...

  6. JAVA 设计模式 桥接模式

    用途 桥接模式 (Bridge) 将抽象部分与实现部分分离,使它们都可以独立的变化. 桥接模式是一种结构式模式. 结构

  7. javascript设计模式-桥接模式

    在系统中,某些类由于自身逻辑,具有两个或两个以上维度的变化,如何使得该类型可以沿多个方向变化,但又不引入额外的复杂度,这就是桥接模式要解决的问题. 定义:桥接模式(Bridge),将抽象部分与它的实现 ...

  8. 设计模式 -- 桥接模式(Bridge Pattern)

    桥接模式 Bridge Pattern 结构设计模式 定义: 分离抽象部分和实现部分,使他们独立运行. 避免使用继承导致系统类个数暴增,可以考虑桥接模式. 桥接模式将继承关系转化为关联关系,减少耦合, ...

  9. [Unity 设计模式]桥接模式(BridgePattern)

    1.前言 继上一讲IOC模式的基础上继续本讲桥接模式,笔者感觉桥接模式是23种设计模式中桥接模式是最好用但也是最难理解的设计模式之一,23中设计模式就好武侠剧中一本武功秘籍,我们在工作过程中想要熟练运 ...

随机推荐

  1. js 字符串 处理方法

    charAt() 返回指定索引位置的字符 charCodeAt() 返回指定索引位置字符的 Unicode 值 concat() 连接两个或多个字符串,返回连接后的字符串 fromCharCode() ...

  2. error C3859: 超过了PCH的虚拟内存范围;请使用“-Zm33”或更大的命令行选项重新编译

    编译 ORB_SLAM的Release版本时,出现了此问题: 错误 2 error C3859: 超过了 PCH 的虚拟内存范围;请使用"-Zm465"或更大的命令行 修改方法: ...

  3. Nginx服务的地址重写

    调整Nginx服务器配置,实现: 1.所有访问a.html的请求,重定向到b.html; 2.所有访问Nginx服务器(192.168.4.1)的请求重定向至www.baidu.com: 3.所有访问 ...

  4. react常用语法

    1.获取dom结构 <div className="Component_projress" ref="projressBar" js中: let proj ...

  5. github+hexo(window10)

    一.申请github账户 二.先安装node.js.git 本地: 三.安装hexo(建立静态网页,用Markdown写博客) 1.创建文件地址 在合适的地方新建一个文件夹,用来存放自己的博客文件,比 ...

  6. 深度遍历DFS

    目录: https://zhipianxuan.github.io/ 一.树的DFS 二.二维矩阵的DFS 三.图的DFS 一.题目一:二维矩阵(输出所有路径数) 思路:从起点开始,DFS,直到走到终 ...

  7. eas之Uuid和BOSUuid 区别

    BOSUuid 加入了BOSType的概念,这个唯一码跟 BOSType有关,里面包含了BOSType的信息. 根据BOSType可以生产BOSUuid,同样,根据BOSUuid也可以找到BOSTyp ...

  8. html第四节课

    css CSS(Cascading Style Sheet,叠层样式表),作用是美化HTML网页. /*注释区域*/    此为注释语法 一.样式表 (一)样式表的分类 1.内联样式表 和HTML联合 ...

  9. Es6获取数据

    $(function(){ $.ajax({ //请求方式 type:"GET", //文件位置 url:"js/data.json", //返回数据格式为js ...

  10. 重新学习html和css

    当初学习前端的时候,属于快速入门那种,没有好好深入学习html和css.如今,在空闲时间重新拿起基础书学习,都会写到一些新的知识. 1.css实现圆角.渐变功能.使用border-radius以及li ...