JS的几种设计模式,Web前端基础三剑客学习知识分享,前端零基础开发

简介: JS的几种设计模式,Web前端基础三剑客学习知识分享,前端零基础开发


  • 组合模式介绍
  • 实现思想
  • 组合模式代码
  • 组合模式的简单应用场景
  • 三、观察者模式
  • 观察者模式介绍
  • 观察者模式介绍实现思想
  • 观察者模式代码
  • 四、发布/订阅模式
  • 发布/订阅模式介绍及实现思想
  • 发布/订阅模式代码

一、单例模式

我们都知道一个构造函数可以使用 new 关键字来创造出若干的实例。并且每个实例都是不相同的。都是不同的地址,比较两个生成的实例时比较的是存储地址,因此每个实例都有不同的存储空间,两者比较值为false

function Person(){
this.name=‘小明’
}
var p1=new Person()
var p2=new Person()
console.log(p1===p2)//false
单例模式介绍

使用构造函数实例化的时候,不管实例化多少回,都实例化出同一个对象

  • 一个构造函数一生只能 new 出一个对象
  • 当我们使用构造函数,每一次 new 出来的对象 属性/功能/方法 完全一样 的时候,我们把他设计成单例模式
核心代码如下
//核心代码
//一个构造函数
function Person() {
this.name = ‘Jack’
}
//全局变量 instance
var instance = null
function singleton() {
if (instance === null) {
instance = new Person()
}
return instance
}
//这是singleton函数第一次调用,这时全局变量instance=null
//因此,instance=new Person()
//全局变量instance的值是Person构造函数的一个实例(将其命名为 实例 001)
//p1 为 实例001
var p1=new singleton()
//这是singleton函数第二次调用,这时全局变量instance 为 实例001
//instance的值不为空 ,因此直接返回 全局变量instance原来的值(实例001)
//p2 为 实例001
var p2=new singleton()
//p1 p2 的值都为实例001 得到的都是同一个对象 因此值为true
console.log(p1===p2)//true
//之后不管再实例化多少回,过程都与第二次调用singleton一致
注意
  • var p1 = new singleton()这里的new关键字并不是实例一个对象,因为p1就是singleton函数的返回值instance构造函数如果返回一个复杂数据类型,那么最后得到的值就是那个复杂数据。这里的实例是构造函数Person的实例。用new关键字只是表示,我们每一次都实例了一个一模一样的对象。
将代码进行优化
  • 这一步我们需要了解JS的闭包以及对构造函数有较为深刻的理解。
  • 闭包的条件
  • 有一个 A 函数,再 A 函数内部返回一个 B 函数
  • 再 A 函数外部有变量引用这个 B 函数
  • B 函数内部访问着 A 函数内部的私有变量
  • 以上三个条件缺一不可
  • 形成闭包后,函数的执行空间不会被销毁,会一直存在。里面的变量也就不会被销毁。
  • 构造函数
  • 一个构造函数可以使用 new 关键字来创造出若干的实例。
  • 每一个实例都可以使用这个构造函数的属性和方法。

想了解JS的闭包,请点击这里

想对构造函数有更多的理解,请点击这里

//外部的Person并不是生成实例的构造函数 new Person 与 Person()得到的值都一样
//最后的结果写成 p = new Person() 是因为p 确实是构造函数的实例,
//不过这个构造函数是内部的Person
//也是因为这样写代码更美观,更直观的看出是用一个构造函数创造相同的实例。
//外部的Person 是一个自执行函数 (function () {})()
// 执行后立马的到返回值 => 实例对象
var Person = (function () {
//这一部分就是我们的核心代码
function Person() {}
var instance = null
//函数返回值 返回一个函数 函数的值是一个实例
return function () {
//利用 三木运算符 简化代码
return !instance ? instance = new Person() : instance
}
})()
//自执行函数 的执行空间不会销毁,形成了一个闭包空间
//执行空间不被销毁 那么instance 这个变量也就不会销毁
//第一次执行得到的是一个Person的实例
//之后的每一次执行,得到的都是第一次的那个实例
p1=new Person()
p2=new Person()
console.log(p1==p2)//true
单例模式的简单应用场景
  • 网站的弹出层alert()或者右下角的广告页面
  • 一个网站不可能只弹出一次这个界面,不能每次弹出就创建一个
  • 每次弹出的都是之前创造好的,只是内容发生变化

二、组合模式

组合模式介绍
  • 举一个简单的例子,就像家里每个电器都有单独的开关,而组合模式就是设置一个总开关,这个开关可以控制家中所有电器的开关,这就是组合模式
实现思想
  • 先定义控制不同电器的开关,也就是一个个构造函数,每一个构造函数都有一个启动方法
  • 每一个构造函数的实例就是一个个电器开关
  • 再定义一个总开关一个构造函数,有一个方法可以启动所有构造函数的,
  • 这时,需要一个承载所有构造函数实例的数组
  • 总开关构造函数需要一个方法, 向数组里面添加内容
  • 总开关构造函数需要一个方法, 能把数组里面的所有内容启动了
组合模式代码
// 一个构造函数的启动方式 控制玩的开关
class Play {
constructor () {}
// 这个构造函数的启动方法
init () {
console.log(‘开始玩游戏’)
this.a()
this.b()
this.c()
}
a () {}
b () {}
c () {}
}
// 第二个构造函数 控制吃的开关
class Eat {
constructor () {}
init () {
console.log(‘去吃饭’)
}
}
//第三个构造函数 控制睡觉的开关
class Sleep {
constructor () {}
init () {
console.log(‘去睡觉’)
}
}
// 组合模式的代码 总开关
class Compose {
constructor () {
// 用来承载每一个实例的数组
this.composeArr = []
}
// 向数组里面添加内容
add (instance) {
this.composeArr.push(instance)
}
// 把数组里面的每一个内容调用了
init () {
console.log(‘总开关启动了’)
this.composeArr.forEach(item => item.init())
}
}
// c 就是一个总开关
var c = new Compose()
// 每一次执行 add 方法就是向总开关上添加内容 使得总开关 可以控制 其他开关
c.add(new Play())
c.add(new Eat())
c.add(new Sleep())
// 只要我的总开关一启动
// 里面的每一个构造函数就同时都启动了
c.init()
console.log©
相关文章
|
12天前
|
前端开发 JavaScript 安全
揭秘!前端大牛们如何高效解决跨域问题,提升开发效率!
【10月更文挑战第30天】在Web开发中,跨域问题是一大挑战。本文介绍前端大牛们常用的跨域解决方案,包括JSONP、CORS、postMessage和Nginx/Node.js代理,对比它们的优缺点,帮助初学者提升开发效率。
35 4
|
10天前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
|
10天前
|
移动开发 前端开发 JavaScript
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
于辰在大学期间带领团队参考网易游戏官网的部分游戏页面,开发了一系列前端实训作品。项目包括首页、2021校园招聘页面和明日之后游戏页面,涉及多种特效实现,如动态图片切换和人物聚合效果。作品源码已上传至CSDN,视频效果可在CSDN预览。
17 0
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
|
15天前
|
JavaScript 前端开发 开发者
前端框架对比:Vue.js与Angular的优劣分析与选择建议
【10月更文挑战第27天】在前端开发领域,Vue.js和Angular是两个备受瞩目的框架。本文对比了两者的优劣,Vue.js以轻量级和易上手著称,适合快速开发小型到中型项目;Angular则由Google支持,功能全面,适合大型企业级应用。选择时需考虑项目需求、团队熟悉度和长期维护等因素。
21 1
|
16天前
|
JavaScript 前端开发 API
前端框架对比:Vue.js与Angular的优劣分析与选择建议
【10月更文挑战第26天】前端技术的飞速发展让开发者在构建用户界面时有了更多选择。本文对比了Vue.js和Angular两大框架,介绍了它们的特点和优劣,并给出了在实际项目中如何选择的建议。Vue.js轻量级、易上手,适合小型项目;Angular结构化、功能强大,适合大型项目。
15 1
|
20天前
|
JavaScript 前端开发 持续交付
构建现代Web应用:Vue.js与Node.js的完美结合
【10月更文挑战第22天】随着互联网技术的快速发展,Web应用已经成为了人们日常生活和工作的重要组成部分。前端技术和后端技术的不断创新,为Web应用的构建提供了更多可能。在本篇文章中,我们将探讨Vue.js和Node.js这两大热门技术如何完美结合,构建现代Web应用。
19 4
|
29天前
|
人工智能 前端开发 测试技术
探索前端与 AI 的结合:如何用 GPT-4 助力开发效率
本文介绍了 GPT-4 如何成为前端开发者的“神队友”,让开发变得更加高效愉快。无论是需求到代码的自动生成、快速调试和性能优化,还是自动化测试和技术选型,GPT-4 都能提供极大的帮助。通过智能生成代码、捕捉 BUG、优化性能、自动化测试生成以及技术支持,GPT-4 成为开发者不可或缺的工具,帮助他们从繁重的手动任务中解脱出来,专注于创新和创意。GPT-4 正在彻底改变开发流程,让开发者从“辛苦码农”转变为“效率王者”。
31 0
探索前端与 AI 的结合:如何用 GPT-4 助力开发效率
|
19天前
|
前端开发 JavaScript UED
"前端小技巧大揭秘:JS如何将后台时间戳秒变亲切小时前、分钟前,让用户秒懂,提升互动体验!"
【10月更文挑战第23天】在Web开发中,将后台返回的时间戳转换为“小时前”、“分钟前”、“刚刚”等友好的时间描述是常见需求。本文介绍如何用JavaScript实现这一功能,通过计算当前时间和时间戳的差值,返回相应的描述,提升用户体验。
25 1
|
15天前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
2月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。