JavaScript设计模式(6)-门面模式

时间:2021-09-29 22:52:52

门面模式

门面模式(Facade Pattern):他隐藏了系统的复杂性,并向客户端提供了一个可以访问系统的接口。这种类型的设计模式属于结构性模式。为子系统中的一组接口提供了一个统一的访问接口,这个接口使得子系统更容易被访问或者使用。

1. 作用:

  • 简化类的接口
  • 消除类与使用它的客户代码之间的耦合

2. 设计一个事件工具

window.DED = window.DED || {};
DED.util = DED.util || {} DED.util.Event = {
getEvent: function(e) {
return e || window.event
},
getTarget: function(e) {
return e.target || e.srcElement
},
stopPropagation: function(e) {
if(e.stopPropagation) {
e.stopPropagation()
} else {
e.cancelBubble = true;
}
},
preventDefault: function(e) {
if(e.preventDefault) {
e.preventDefault()
} else {
e.returnValue = false;
}
},
stopEvent: function(e) {
this.stopPropagation(e);
this.preventDefault(e);
}
} function addEvent(el, type, fn) {
if (window.addEventListener) {
el.addEventListener(type, fn, false);
} else if (window.attachEvent) {
el.attachEvent('on'+ type, fn);
} else {
el['on' + type] = fn;
}
} // usage
addEvent(document.querySelector('button'), 'click', function(e){
console.log(DED.util.Event.getEvent(e))
console.log(DED.util.Event.getTarget(e))
console.log(DED.util.Event.stopEvent(e))
})

3. 实现门面模式的一般步骤

  • 找准自己应用程序中感觉适合使用门面方法的地方
    • 两个函数经常同时出现在一个地方
    • 需要处理跨浏览器的差异问题
  • 起一个适合的名字

4. 门面模式的利与弊

  • 利:
    • 编写一次组合代码,然后可以反复利用个,节省时间和精力
    • 简化接口
    • 降低对外部代码的依赖程度
    • 可以避免与下层子系统紧密耦合,这样可以对这个系统进行修改而不会影响到客户代码
  • 弊:
    • 滥用会带来不必要的负担,有时并不需要使用门面模式

注意

转载、引用,但请标明作者和原文地址

JavaScript设计模式(6)-门面模式的更多相关文章

  1. JavaScript设计模式-12.门面模式

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. JavaScript设计模式之----组合模式

    javascript设计模式之组合模式 介绍 组合模式是一种专门为创建Web上的动态用户界面而量身制定的模式.使用这种模式可以用一条命令在多个对象上激发复杂的或递归的行为.这可以简化粘合性代码,使其更 ...

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

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

  4. 设计模式&lowbar;Facade&lowbar;门面模式

    形象例子: 我有一个专业的Nikon相机,我就喜欢自己手动调光圈.快门,这样照出来的照片才专业,但MM可不懂这些,教了半天也不会.幸好相机有Facade设计模式,把相机调整到自动档,只要对准目标按快门 ...

  5. JavaScript设计模式之策略模式(学习笔记)

    在网上搜索“为什么MVC不是一种设计模式呢?”其中有解答:MVC其实是三个经典设计模式的演变:观察者模式(Observer).策略模式(Strategy).组合模式(Composite).所以我今天选 ...

  6. 再起航,我的学习笔记之JavaScript设计模式08&lpar;建造者模式&rpar;

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...

  7. 再起航,我的学习笔记之JavaScript设计模式09&lpar;原型模式&rpar;

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 我们 ...

  8. 再起航,我的学习笔记之JavaScript设计模式11&lpar;外观模式&rpar;

    经过一段时间的学习与分享,我们对创建型设计模式已经有了一定的认识,未来的一段时间里我们将展开新的篇章,开始迈入结构性设计模式的学习. 结构性设计模式与创建型设计模式不同,结构性设计模式更偏向于关注如何 ...

  9. 再起航,我的学习笔记之JavaScript设计模式14&lpar;桥接模式&rpar;

    桥接模式 桥接模式(Bridge): 在系统沿着多个维度变化的同时,又不增加其复杂度并已达到解耦 从定义上看桥接模式的定义十分难以理解,那么我们来通过示例来演示什么是桥接模式. 现在我们需要做一个导航 ...

随机推荐

  1. js正则表达式校验非负整数:&Hat;&bsol;d&plus;&dollar; 或 &Hat;&lbrack;1-9&rsqb;&bsol;d&ast;&vert;0&dollar;

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. 在移动端如何选择字体大小和布局的单位&comma;px或dp&quest;

    android开发中,文字大小的单位是sp,非文字的尺寸单位用dp,但是我们在设计稿用的单位是px.这些单位如何换算,是设计师.开发者需要了解的关键. 简单理解的话,px(像素)是我们UI设计师在PS ...

  3. 笔记:ASP&period;NET MVC安全

    XSRF/CSRF Prevention in MVC ValidateAntiForgeryToken 参考这里的简单例子:http://www.asp.net/mvc/tutorials/mvc- ...

  4. PHP header&lpar;&rpar;函数

    对header函数,我用得最多的就是跳转页面和设置字符集,其他的功能用得比较少. 一.设置字符集 其实我们用的最多的在在html代码当中的<meta>标签里面设置字符集.格式如下: &lt ...

  5. Android Manifest&period;xml详解

    一.关于AndroidManifest.xml AndroidManifest.xml 是每个android程序中必须的文件.它位于整个项目的根目录,描述了package中暴露的组件(activiti ...

  6. 关于Windows高DPI的一些简单总结(Window上一般默认是96 dpi 作为100&percnt; 的缩放比率)

    我们知道,关于高DPI的支持, Windows XP时代就开始有了, 那时关于高DPI的支持比较简单, 但是从Vista/Win7 到现在Win8 /Win8.1, Windows关于高DPI的支持已 ...

  7. 缺少libssl&period;so&period;4文件

    1.报错代码: /usr/local/pureftpd/sbin/pure-ftpd: error while loading shared libraries: libssl.so.4: wrong ...

  8. ffmpeg-4&period;1&period;1-win64-dev在vs2017的搭建

    没得话讲,先在官网下载对应的源码,下载dev/文件夹下的源码和静态链接库  ,下载/shared文件夹下的动态链接库 官网地址:https://ffmpeg.zeranoe.com/builds/wi ...

  9. python之路:列表及元组之定义

      python开发之路:列表及元组之定义 列表是以后用处较大的一个数据类型,这种数据类型可以存储按组分类的信息.好了,我不多说,开始讲了! 好了,现在我有个情景,我要存东汉时期(韩国,秦国,……)所 ...

  10. 将16进制unsigned char数组转换成整数

    /** * 将unsigned char数组转换成long long数值 * {0x00 0x00 0x20 0x00}转换之后得到8192 * * @param str 数组 * @param le ...