前言:这段时间都在学习Vue的知识,虽然手边放着一本js高程,但确实好久没有好好复习了。温故而知新,因此特意把JS常见的设计模式总结,希望对大家有所帮助...

1. 工厂模式

释义:像工厂一样流水线般生产一个个对象

核心:return一个对象,创建不同的引用类型

// 工厂模式
function createPerson (){
//定义工厂
let person = {
name:'人',
walk:function(){
console.log('walk')
}
}
return person
}
let tangj = createPerson()
console.log(tangj.name) // 人

2. 构造函数模式

释义:在JavaScript里,构造函数通常是认为用来实现实例的,JavaScript没有类的概念,但是有特殊的构造函数。通过new关键字来调用自定义的构造函数,在构造函数内部,this关键字引用的是新创建的对象。

核心:属性邦到this上,方法绑到prototype上,使用new来新增实例

function People(){
this.name = '人' //把属性写在构造函数内部
}
People.prototype.walk = function(){
console.log('walk') //方法写在原型对象上
}
let tangj = new People()
console.log(tangj.name) //人

3. 单例模式

释义:保证一个类只有一个实例,并且仅提供一个访问它的全局访问点

核心:产生一个类的唯一实例

//单例模式
function createPeople (){
let name;
return function (useName){
return name || (name = useName) //如果name存在返回name,如果不存在返回传入的值
}
}
let single = createPeople()
console.log(single('tangj')) //tangj
console.log(single()) //tangj
console.log(single('tangjSir')) //tangj

4. 混合模式

释义:一般继承的过程就是混合模式

核心:提供能够被一个或一组子类简单继承功能的类

//混合模式
function People(name,age){
this.name = name
this.age = age
}
People.prototype.sayName = function(){
console.log(this.name)
}
function Student(name,age,score){
People.call(this,name,age);
this.score = score;
}
function creat(prototypeObj){
let empty = function(){};
empty.prototype = prototypeObj;
return new empty()
}
Student.prototype = creat(People.prototype);
Student.prototype.work = function(){
console.log('work')
}

5. 模块模式

核心:闭包

let Person = (function(){
let name = '小明';
function sayName(){
console.log(name)
}
return {
name:name,
sayName:sayName
}
})()
Person.sayName()//小明

6. 发布订阅模式

释义:多个订阅者绑定一个发布者,当订阅者监听到发布者变化执行回调函数

核心:绑定事件

let EventCenter = (function(){
let events = {};
function on(evt,handler){
//实现监听
//使用“或”是为了可以对同一个事件多次进行回调
events[evt] = events[evt] || [];
events[evt].push({
handler:handler
})
}
function fire(evt,args){
if(!events[evt]){
return
}
for(let i = 0;i<events[evt].length;i++){
//遍历实现对同一事件的多次回调
events[evt][i].handler(args)
}
}
function off(name){
delete events[name];
}
return {
on:on, //订阅者
fire:fire, //发布者
off:off //取消订阅
}
})() EventCenter.on('hello',function (num){
console.log(num)
})
EventCenter.on('hello',function(num){
console.log(num)
})
EventCenter.fire('hello',1) //打印两次 1

【学习笔记】JS设计模式总结的更多相关文章

  1. amazeui学习笔记--js插件(UI增强)--警告框Alert

    amazeui学习笔记--js插件(UI增强)--警告框Alert 一.总结 1.警告框基本样式:用am-alert声明div容器, <div class="am-alert" ...

  2. amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown

    amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown 一.总结 1.am-dropdown(及其孩子):控制下拉列表的样式 2.data-am-dropdown(及其孩子):控 ...

  3. amazeui学习笔记--js插件(UI增强3)--折叠面板Collapse

    amazeui学习笔记--js插件(UI增强3)--折叠面板Collapse 一.总结 注意点: 1.data-am-collapse:这个东西就是展开折叠事件 2.am-collapse(包括其下属 ...

  4. amazeui学习笔记--js插件(UI增强2)--按钮交互Button

    amazeui学习笔记--js插件(UI增强2)--按钮交互Button 一.总结 1.按钮loading状态: <button type="button" class=&q ...

  5. 前端学习:学习笔记(JS部分)

    前端学习:学习笔记(JS部分) 前端学习:JS学习总结(图解)    JS的简介 JS基本语法 JS内置对象 JS的函数 JS的事件 JS的BOM JS的DOM JS的简介 新建步骤 <body ...

  6. JavaScript学习笔记——JS中的变量复制、参数传递和作用域链

    今天在看书的过程中,又发现了自己目前对Javascript存在的一个知识模糊点:JS的作用域链,所以就通过查资料看书对作用域链相关的内容进行了学习.今天学习笔记主要有这样几个关键字:变量.参数传递.执 ...

  7. [学习笔记]JS 数组Array push相关问题

    前言: 今天用写了一个二维数组,都赋值为零,然后更新其中一个值,结果和预期是不一样,会整列的相同位置都是同一个值. 1.用Chrome的控制台样例如下: arrs[2][2] =1的赋值,竟然是三个数 ...

  8. [学习笔记]JS计数器,闭包和localStorage

    1.前言 Javascript也算用了挺久了,为了得到一个变量,类似Java的静态变量的功能,我想到了很早以前学习JS的闭包,还有做俄罗斯方块的排行榜用到LocalStorage技术,所以想总结一下, ...

  9. [置顶] 我的设计模式学习笔记------>Java设计模式总概况

    设计模式的概念最早起源于建筑设计大师Alexander的<建筑的永恒方法>一书,尽管Alexander的著作是针对建筑领域的,但是他的观点实际上用用于所有的工程设计领域,其中也包括软件设计 ...

  10. 读书笔记:js设计模式

    面向过程编程,面向对象编程和函数式编程> 定义一个类方法1:function Anim(){ } Anim.prototype.start = function(){ .. };Anim.pro ...

随机推荐

  1. KD-树(上)

    来自于https://zhuanlan.zhihu.com/p/23966698 思路篇 导语:kd 树是一种二叉树数据结构,可以用来进行高效的 kNN 计算.kd 树算法偏于复杂,本篇将先介绍以二叉 ...

  2. 【NIFI】 Apache NiFI 安装及简单的使用

    NiFI介绍 NiFi(NiagaraFiles)是为了实现系统间数据流的自动化而构建的.虽然术语“数据流”用于各种上下文,但我们在此处使用它来表示系统之间的自动和管理信息流 官网地址:http:// ...

  3. Java程序员职业生涯规划

    一.规划 工作3年了,感觉自己的技术现在到了一个瓶颈,在做一些重复性的业务性的工作,没有长进,提高太慢:因此停下脚步对自己的职业生涯做了一个规划,并为之努力奋斗: 20-27岁:技术积累阶段在这 5 ...

  4. Vuejs——(12)组件——动态组件

    版权声明:出处http://blog.csdn.net/qq20004604   目录(?)[+]   本篇资料来于官方文档: http://cn.vuejs.org/guide/components ...

  5. Android-Java-饿汉式单例模式(内存图)

    描述Single对象: package android.java.oop14; public class Single { // 默认构造方法 私有化 不让外界调用 private Single() ...

  6. Instruments Time Profiler时,无法定位代码,如何破?

    都是地址符号,往深里也一直是地址符号,根本没法判断是哪些代码的执行时间 解决办法: 选下面的.

  7. Rabbit RPC 代码阅读(一)

    前言 因为想对RPC内部的机制作一个了解,特作以下阅读代码日志,以备忘. RPC介绍 Rabbit RPC 原理可以用3点概括: 1.服务端启动并且向注册中心发送服务信息,注册中心收到后会定时监控服务 ...

  8. samba 配置文件解析

    [global] #定义全局策略 workgroup=MYGROUP #定义工作组 netbios name=MYSERVER #指定NetBios名称 interfaces=lo 192.168.1 ...

  9. jsapi微信支付

    JSAPI微信支付 引用js <script type="text/javascript" src="http://res.wx.qq.com/open/js/jw ...

  10. IPv6技术详解:基本概念、应用现状、技术实践(下篇)

    本文来自微信技术架构部的原创技术分享. 1.前言 在上篇<IPv6技术详解:基本概念.应用现状.技术实践(上篇)>,我们讲解了IPV6的基本概念. 本篇将继续从以下方面展开对IPV6的讲解 ...