前端23种js设计模式中参见的7种设计模式的学习
创建型设计模式
是一类处理对象创建的设计模式,通过某种方式控制对象的创建来避免基本对象创建时可能导致设计上的问题或增加设计上的复杂度。
1)工厂模式
class Product {
constructor(options) {
this.name = options.name;
this.time = options.time;
this.init();
}
init() {
console.log(`产品名:${this.name} 保质期:${this.time}`);
}
}
class Factory {
create(options) {
return new Product(options);
}
}
let factory = new Factory();
let product1 = factory.create({ name: "面包", time: "1个月" });
2)单例模式 (一个类只有一个实例)
function SingleObject() {
this.name = "单例";
}
SingleObject.getInstance = function() {
if (!this.instance) {
this.instance = new SingleObject();
}
return this.instance;
};
var obj1 = SingleObject.getInstance();
var obj2 = SingleObject.getInstance();
console.log(obj1 === obj2);
结构型设计模式
关注于如何将类或对象组合成更大、更复杂的结构,以简化设计。
1)适配器模式
// 新增加的适配器
class Adaptee {
constructor() {
this.name = "我是适配器";
}
parse() {}
} // 原来的旧代码
class OldApi{
constructor(){
this.name = '我是旧的接口'
this.adaptee = new Adaptee()
this.adaptee.parse()
}
} var oldApi = new OldApi()
2)装饰器模式
class Circle {
draw() {
console.log("draw");
}
}
class Decorator{
constructor(circle) {
this.circle = circle
}
setRedBorder() {
console.log('border装饰为红色')
}
draw() {
this.circle.draw()
this.setRedBorder()
}
}
let circle = new Circle()
let decorator = new Decorator(circle)
circle.draw()
decorator.draw()
3)代理模式【无法直接访问时,通过代理来访问目标对象】
class Data{
constructor(){
this.name = '元数据'
}
getName(){
console.log(this.name)
}
}
class ProxyData{
constructor(data){
this.data = data
}
getName(){
this.data.getName()
}
}
let data = new Data()
let proxyData = new ProxyData(data)
data.getName()
proxyData.getName()
行为型设计模式
用于不同对象之间职责划分或者算法抽象,行为型设计模式不仅仅涉及类和对象,还涉及类或对象之间的交流模式并加以实现。
1)观察者模式
class EventEmitter {
constructor() {
this.eventMap = {};
}
on( type, fn ) {
if ( !this.eventMap[type] ) {
this.eventMap[type] = []
}
this.eventMap[type].push(fn)
}
emit( type, ...params ) {
this.eventMap[type].forEach(fn => {
fn(...params);
});
}
off( type, fn ) {
let list = this.eventMap[type];
let atIndex = list.indexOf(fn);
if (atIndex !== -1) {
list.splice(atIndex, 1);
}
}
}
2)迭代器模式【1.按顺序访问集合, 2.调用者不用关心内部的数据结构】
function each(data) {
let iterator = data[Symbol.iterator]();
let item = { done: false };
while (item.done === false) {
item = iterator.next();
if ( item.done ) return item
console.log(item)
}
}
let arr = [1, 2, 3, 4];
let nodeList = document.querySelectorAll("p");
let m = new Map();
m.set("a", 100);
m.set("b", 100);
each(arr)
each(nodeList)
each(m)
class Iterator{
constructor(wrapper) {
this.list = wrapper.list
this.index = 0
}
next() {
if ( this.hasNext() ) {
return this.list[this.index++]
} else {
return null
}
}
hasNext() {
return this.index < this.list.length
}
}
class Wrapper {
constructor(list) {
this.list = list
}
getIterator(iterator) {
return new Iterator(this)
}
}
var arr = [1, 2, 3]
var iterator = new Wrapper( arr ).getIterator()
while ( iterator.hasNext() ) {
console.log(iterator.next())
}
参考文献: https://segmentfault.com/a/1190000017145504
前端23种js设计模式中参见的7种设计模式的学习的更多相关文章
- js正则表达式中的问号几种用法小结
这篇文章主要介绍了js正则表达式中的问号几种用法,比如+?,*?,{2,3}?可以停止匹配的贪婪模式,感兴趣的朋友可以参考下 在表示重复的字符后面加问号,比如+?,*?,{2,3}?可以停止匹配的贪婪 ...
- thinkphp在前端页面的js代码中可以使用 U方法吗? 可以使用模板变量如__URL__等吗?
thinkphp在前端页面的js代码中可以使用 U方法吗? : 可以的! tp的U方法, 是"全局的", 什么是全局的? 就是, 可以在 "任何地方"使用的: ...
- JS数组中every(),filter(),forEach(),map(),some()方法学习笔记!
ES5中定义了五种数组的迭代方法:every(),filter(),forEach(),map(),some(). 每个方法都接受两个参数:要在每一项运行的函数(必选)和运行该函数的作用域的对象-影响 ...
- 对比几种在ROS中常用的几种SLAM算法
在此因为要总结写一个文档,所以查阅资料,将总结的内容记录下来,欢迎大家指正! 文章将介绍使用的基于机器人操作系统(ROS)框架工作的SLAM算法. 在ROS中提供的五种基于2D激光的SLAM算法分别是 ...
- js正则表达式中的问号使用技巧总结
这篇文章主要介绍了js正则表达式中的问号几种用法,比如+?,*?,{2,3}?可以停止匹配的贪婪模式等例子的解析. 在表示重复的字符后面加问号,比如+?,*?,{2,3}?可以停止匹配的贪婪模式. v ...
- Java中创建对象的五种方式
我们总是讨论没有对象就去new一个对象,创建对象的方式在我这里变成了根深蒂固的new方式创建,但是其实创建对象的方式还是有很多种的,不单单有new方式创建对象,还有使用反射机制创建对象,使用clone ...
- 服务器文档下载zip格式 SQL Server SQL分页查询 C#过滤html标签 EF 延时加载与死锁 在JS方法中返回多个值的三种方法(转载) IEnumerable,ICollection,IList接口问题 不吹不擂,你想要的Python面试都在这里了【315+道题】 基于mvc三层架构和ajax技术实现最简单的文件上传 事件管理
服务器文档下载zip格式 刚好这次项目中遇到了这个东西,就来弄一下,挺简单的,但是前台调用的时候弄错了,浪费了大半天的时间,本人也是菜鸟一枚.开始吧.(MVC的) @using Rattan.Co ...
- Mybatis 中经典的 9 种设计模式!面试可以吹牛了
虽然我们都知道有23个设计模式,但是大多停留在概念层面,真实开发中很少遇到.Mybatis源码中使用了大量的设计模式,阅读源码并观察设计模式在其中的应用,能够更深入的理解设计模式. Mybatis至少 ...
- 在JS方法中返回多个值的三种方法
在使用JS编程中,有时需要在一个方法返回两个个或两个以上的数据,用下面的几种方法都可以实现: 1 使用数组的方式,如下: <html> <head> <title> ...
随机推荐
- IDEA导入外部code style
至于用何种代码风格, 根据自己团队规范来吧 提供一个Google的IDEA java风格吧 Github地址 原文地址:https://blog.csdn.net/sasuke__/article/d ...
- luogu P4755 Beautiful Pair
luogu 这题有坨区间最大值,考虑最值分治.分治时每次取出最大值,然后考虑统计跨过这个位置的区间答案,然后两边递归处理.如果之枚举左端点,因为最大值确定,右端点权值要满足\(a_r\le \frac ...
- Darknet版YOLO安装与配置
Darknet配置和安装 1. 安装显卡驱动 首先查看一下自己的电脑需要怎样的驱动,我们可以先到 http://www.nvidia.com/Download/index.aspx 查询下我们需要的是 ...
- 2019.9.19HTML基础
html:超文本标记语言,不是编程语言,是标签语言,显示数据. 有双标签和单标签 双标签:有开始有结束,<body></body> 单标签:只有一个.<img src=# ...
- 最完美ThinkPHP Nginx 配置文件
一个配置文件,完美支持普通,兼容,pathinfo,rewrite4种url模式,别怪我没提醒你收藏哦. 常见的静态文件404时也不会再去跑一遍fastcgi浪费资源. server { listen ...
- 文件操作相关函数(POSIX 标准 open,read,write,lseek,close)
POSIX标准 open函数属于Linux中系统IO,用于“打开”文件,代码打开一个文件意味着获得了这个文件的访问句柄. int fd = open(参数1,参数2,参数3): int fd = op ...
- hibernate中Session的load和get方法的区别是什么?
主要有以下三项区别: ① 如果没有找到符合条件的记录,get方法返回null,load方法抛出异常. ② get方法直接返回实体类对象,load方法返回实体类对象的代理. ③ 在Hibernat ...
- qt5-信号和槽
信号函数: connect(btn,&QPushButton::clicked,this,&QWidget::close); //参数1 信号发送者://参数2 信号:---& ...
- Python 面向对象Ⅱ
创建实例对象 实例化类其他编程语言中一http://www.xuanhe.net/般用关键字 new,但是在 Python 中并没有这个关键字,类的实例化类似函数调用方式. 以下使用类的名称 Empl ...
- 31.整数中1出现的次数(从1到n整数中1出现的次数)
题目描述 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1.10.11.12.13因此共出现6次,但是对于后面问题他就没辙了. ...