门面模式

这是一种组织性的模式,它可以用来修改类和对象的接口,使其更便于使用。它可以让程序员过得更轻松,使他们的代码变得更容易管理。

门面模式有两个作用:

  1. 简化类的接口
  2. 消除与使用她的客户代码之间的耦合

一个简单的门面模式

var addEvent = function(el, ty, fn){
var cases = [
function(el, ty, fn) { el.addEventListener(ty, fn, false); },
function(el, ty, fn) { el.attachEvent('on'+ty, fn); },
function(el, ty, fn) { el['on'+ty] = fn; }
];
if(el.addEventListener){
$.addEvent = cases[0];
}else if(el.attachEvent){
$.addEvent = cases[1];
}else{
$.addEvent = cases[2];
}
$.addEvent(el, ty, fn);
},

addEvent函数就是一个基本的门面,有了它,就可以把检查代码封装在一个地方,这可以让代码变得更简洁。这是一个应用门面模式对付一组设计得比较糟糕的API的案例,其具体做法就是用一个精心设计的API来包装她们。

用作便利函数的门面模式

function a(x){
return x;
}
function b(x){
return y;
}
function ab(x, y){
a(x);
b(y);
}

门面模式的另一个好处表现在对函数的组合上。这些组合而得的函数又叫便利函数

其实我们完全可以将a,b两个函数在一开始的时候就放入到ab函数中,那么门面模式在这里有什么好处呢?

答案是分别提供a、b和ab这几个函数可以获得更多力度控制和灵活性。组合a和b可能会对应用程序造成破坏或者意想不到的结果。

下面就是一个常见的门面模式:

var JChen = window.JChen || {};
JChen.util = {
stopPropragation: function(e){
if(e.stopPropragation){
e.stopPropragation();
}else{
e.cancelBubble = true;
}
},
preventEvent: function(e){
if(e.preventEvent){
e.preventEvent();
}else{
e.returnValue = false;
}
},
stopEvent: function(e){ //这个就是便利函数
JChen.util.stopPropragation(e);
JChen.util.preventEvent(e);
}
};

设置HTML样式

基本做法

设置HTML的样式,只要对样式对象的特定属性赋值即可,例如:

var el = document.getElementById('content');
el.style.color = 'red';

门面模式

现在假设我们要一次设置几个元素的某个样式。如果分别设置显然是有些笨拙的,这个时候我们就可以使用门面模式了。

function setStyle(el, prop, val){
for(var i= 0, len=el.length; i<len; i++){
document.getElementById(el[i]).style[prop] = val;
}
}
setStyle(['foo', 'bar'], 'color', 'red');

稍加改进

要是我们还可以一次设置多个元素的多个样式就更好了,那样的话就不必反复使用setStyle方法了。

function setCSS(el, styles){
for( var prop in styles){
if(!styles.hasOwnProperty(prop)){ //必须不能是原型上的属性才是应该被设置的样式
continue;
}
styles(el, prop, styles[prop]);
}
}
setCSS(['foo', 'bar'], {
color: 'white',
background: 'black',
fontSize: '16px'
});

现在我们又用了一个门面模式去包含了刚才的门面模式,这下就正点多了。

门面模式的使用场合

判断是否应该应用门面模式的关键在于辨认那些反复成组出现的代码。如果函数b经常出现在函数a之后,那么门面模式就派上用场了。

另一个可能的目的是应对Javascript内置函数在不同浏览器中的表现的情况。addEvent就是其中一例。

门面模式之利

编写一次组合代码,然后就可以反复使用他,这有助于节省时间和精力。

通过门面模式,可以避免与下层子系统紧密耦合。这样可以对这个系统进行修改而不影响到客户代码。(也就是多粒度的控制)

门面模式之弊

有时候门面元素也会带来一些不必要的额外负担。方便的东西不一定就得用。门面模式常常会被滥用。在使用你心仪的门面函数之前请三思。

JS设计模式——10.门面模式的更多相关文章

  1. JS设计模式——5.单体模式

    JS设计模式——5.单体模式 http://www.cnblogs.com/JChen666/p/3610585.html   单体模式的优势 用了这么久的单体模式,竟全然不知!用它具体有哪些好处呢? ...

  2. python 设计模式之门面模式

    facade:建筑物的表面 门面模式是一个软件工程设计模式,主要用于面向对象编程. 一个门面可以看作是为大段代码提供简单接口的对象,就像类库.   门面模式被归入建筑设计模式.门面模式隐藏系统内部的细 ...

  3. js设计模式——7.备忘录模式

    js设计模式——7.备忘录模式 /*js设计模式——备忘录模式*/ // 备忘类 class Memento { constructor(content) { this.content = conte ...

  4. js设计模式——6.模板方法模式与职责链模式

    js设计模式——6.模板方法模式与职责链模式 职责链模式

  5. js设计模式——5.状态模式

    js设计模式——5.状态模式 代码演示 /*js设计模式——状态模式*/ // 状态(红灯,黄灯,绿灯) class State { constructor(color) { this.color = ...

  6. js设计模式——4.迭代器模式

    js设计模式——4.迭代器模式 代码演示 /*js设计模式——迭代器模式*/ class Iterator { constructor(container) { this.list = contain ...

  7. js设计模式——2.外观模式

    js设计模式——2.外观模式

  8. js设计模式——1.代理模式

    js设计模式——1.代理模式 以下是代码示例 /*js设计模式——代理模式*/ class ReadImg { constructor(fileName) { this.fileName = file ...

  9. js设计模式:工厂模式、构造函数模式、原型模式、混合模式

    一.js面向对象程序 var o1 = new Object();     o1.name = "宾宾";     o1.sex = "男";     o1.a ...

随机推荐

  1. Angular中sweetalert弹框的使用详解

    最近太忙了,项目中使用的弹框老板嫌太丑,让我们优化一下,我在网上找了一下,找到了sweetalert弹框,算是比较好看的弹框了.所以我就想办法将sweetalert用到项目中,在项目中引入sweeta ...

  2. API接口测试中需要注意的地方

    1.检查接口返回的数据是否与预期结果一致. 2.检查接口的容错性,假如传递数据的类型错误时是否可以处理.例如是支持整数,传递的是小数或字符串呢? 3.接口参数的边界值.例如,传递的参数足够大或为负数时 ...

  3. 利用VRID/VMAC实现更安全的netscaler HA故障切换

    利用VRID/VMAC实现更安全的netscaler HA故障切换 virtual MAC在故障切换(failover)中的作用.    在一个HA模式中,首要节点(primary node)拥有所有 ...

  4. 【题解】CF#896 D-Nephren Runs a Cinema

    容易发现这些 vip 用户并没什么用,所以考虑枚举手持50元与100元的人共有多少个.设手持50元的人 \(a\) 个,手持100元的人 \(a - k\) 个,那么一共是 \(2*a - k\) 个 ...

  5. Unity使用C#实现简单Scoket连接及服务端与客户端通讯

    简介: 网络编程是个很有意思的事情,偶然翻出来很久之前刚开始看Socket的时候写的一个实例,贴出来吧 Unity中实现简单的Socket连接,c#中提供了丰富的API,直接上代码. 服务端代码: [ ...

  6. BZOJ 2720: [Violet 5]列队春游

    2720: [Violet 5]列队春游 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 189  Solved: 133[Submit][Status] ...

  7. 【转】高手带你深入理解ucos任务堆栈

    首先,我们来理解一下两个概念: 1.堆栈就是一段连续的空间.用于存储数据的,在c计算机中有很多应用,比如发生中断时保存现场,c语言函数调用时保存现场和临时变量. 2.堆栈指针就是一个数据指针.有时候计 ...

  8. 2018.9.21 Codeforces Round #511(Div.2)

    只写了AB,甚至还WA了一次A题,暴露了蒟蒻的本质=.= 感觉考的时候有好多正确或和正解有关的思路,但是就想不出具体的解法或者想的不够深(长)(怕不是过于鶸) 话说CF的E题怎么都这么清奇=.= A. ...

  9. LGP4577【JSOI2018】战争

    题解: 求出$A$ 和$-B$ 的$Minkowsiki$和再$O(logn)$判断一个点是否在凸包内: $Minkowsiki$的求法比较容易忘,要多多温习才可以: #include<bits ...

  10. 菜鸟合作伙伴日志接入规范之C#实现

    由于行业的业务功能需要,需要与菜鸟对接登录日志,将我们系统的用户登录信息提交给菜鸟,菜鸟分析通过分析日志,检查存在的一些安全问题.根据菜鸟提供的标准,实现了C#的接入,下面分享给大家,让需要的朋友少走 ...