JS的设计模式

一、什么是设计模式?

  (一)设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。

二、单例模式

  (一) 概念:单个实例,只有一个对象,多次创建,返回同一个对象。单例模式的核心:确保只有一个实例,并提供全局访问。

  (二) 实现浮窗

三、 组合模式

  (一) 组合多个对象形成树形结构以表示具有“整体-部分”关系的层次结构。组合模式对单个对象(即叶子对象)和组合对象(即容器对象)的使用具有一致性,组合模式又可以称为“整体-部分”模式,它是一种对象结构型模式。

四、观察者模式

  (一) 观察者模式又叫发布-订阅模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知。

五、MV*模式

  (一) MVC 模式的意思是,软件可以分成三个部分:

    1. 视图(view):用户界面

    2. 控制器(controller):业务逻辑

    3. 模型(Model):数据保存

    4. 各部分之间的通信方式如下:

      

      

      1) View 传送指令到 Controller

      2) Controller 完成业务逻辑后,要求 Model 改变状态

      3) Model 将新的数据发送到 View,用户得到反馈

      4) 所有通信都是单向的。

    5. Model

      1) Model 管理应用程序的数据。

      2) Model 不涉及用户界面,也不涉及表示层,而是代表应用程序可能需要的独特形式的数据。

      3) 当 Model 改变时,它通常会通知它的观察者(如 View)。

      4) 一个 Model 模型可能有多个观察它的View。

      5) 总而言之,Model 主要与业务数据有关。

    6. View

      1) View 是 Model 的可视化表示

      2) 一个View通常检测一个Model,并在Model更改时进行通知,使 View 本身能够相应地更新。

      3) 用户可以和 View 进行交互,包括读取和编辑 Model。

      4) 由于 View 是表示层,通常我们能够以一种更友好的方式进行编辑和更新。

      5) 而更新 Model 的实际任务其实是在Controller 上的。

      6) View 是应用程序数据的可视化表示

    7. Controller

      1) Controller 是 Model 和 View 之间的中介,当用户操作 View 时,它通常负责更新Model。

    8. MVC 的优点

      1) MVC 这种关注点分离有利于进一步简化应用程序功能的模块化,并能够实现:整体维护更容易。

      2) 解耦 Model 和 View,意味着它能够更直接地编写业务逻辑的单元测试

      3) 这种模块性可以让负责核心逻辑的开发人员和负责用户界面的开发人员同时工作。

  (二) MVP

    1. MVP 是 MVC 的一种衍生模式,专注于改进表示逻辑。

    2. Presenter

      1) MVP 中的 P 代表表示器。这是一个包含用于 View 的用户界面业务逻辑的组件。

        

        a) 各部分之间的通信,都是双向的。

        b) View 与 Model 不发生联系,都通过Presenter 传递。

        c) View 非常薄,不部署任何业务逻辑,称为“被动视图”(Passive View),即没有任何主动性,而 Presenter 非常厚,所有逻辑都部署在那里。

  (三) MVP 与 MVC

    1. MVP 适用于有非常复杂的 View 和大量用户交互的应用程序。

    2. 这样的程序如果用 MVC 的话意味着要极度依赖于多个控制器。而在 MVP 中,所有这些复杂的逻辑可以封装在一个表示器中,大大简化维护工作。

  (四) MVVM

    1. MVVM 模式将 Presenter 改名为 ViewModel,基本上与 MVP 模式完全一致。

    

    

    2. 唯一的区别是,它采用双向绑定(data-binding):View 的变动,自动反映在ViewModel,反之亦然。

    3. MVVM 由 Model,View,ViewModel 三部分构成:

      1) Model 层代表数据模型,也可以在 Model中定义数据修改和操作的业务逻辑

      2) View 代表 UI 组件,它负责将数据模型转化成 UI 展现出来

      3) ViewModel 是一个同步 View 和 Model 的对象。

    4. 在 MVVM 架构下,View 和 Model 之间并没有直接的联系,而是通过 ViewModel 进行交互,Model 和 ViewModel 之间的交互是双向的,因此 View 数据的变化会同步到 Model 中,而Model 数据的变化也会立即反应到 View 上。

    5. ViewModel 通过双向数据绑定把 View 层和Model 层连接了起来,而 View 和 Model 之间的同步工作完全是自动的,无需人为干涉,因此开发者只需关注业务逻辑,不需要手动操作DOM,不需要关注数据状态的同步问题,复杂的数据状态维护完全由 MVVM 来统一管理。

    6. View 与 ViewModel

      1) MVVM 中的 View 是主动而不是被动的。

      2) 被动 View 只输出显示并不接受任何用户输入

      3) 而 MVVM 中的 View 和 ViewModel 之间通过数据绑定和事件进行通信。

      4) 优点:

        a) MVVM 使得 UI 和为 UI 提供驱动的行为模块的并行开发变得更容易。

        b) MVVM 使 View 抽象化,从而减少代码背后所需的业务逻辑量。

        c) ViewModel 在单元测试中的使用更容易

      5) 缺点:

        a) 对于简单的 UI 来说,使用 MVVM 有些大材小用

        b) 数据绑定难以调试

      6) VUE 是典型的 MVVM 框架,它实现双向数据绑定的技术是数据劫持。也就是通过 ES5提供的 Object.defineProperty()方法来劫持(监控)各属性的 getter、setter,并在数据(对象)发生变动时通知订阅者,触发相应的监听回调。

六、Webpack

  (一)什么是 webpack?

    1. 其实 webpack 在翻译过来是一个打包器,对啥进行打包呢?我们项目中的 sass、less、js这些零零碎碎的东西,整合在一起。

  (二) Webpack 的优势是什么?

    1. 丰富的插件,方便进行开发工作

    2. 大量的加载器,包括加载各种静态资源

    3. 代码分割,提供按需加载的

  (三) Webpack 的安装

    1、安装webpack的运行环境nodejs;注: 安装路径!不能有中文!

    2、win + r : 打开运行, 输入cmd进入命令窗口

    3、测试nodejs是否安装成功? 命令行: node -v 如果返回版本号,安装成功

    4、如果npm运行慢,可以安装国内淘宝镜像 cnpm:

      npm install -g cnpm --registry=https://registry.npm.taobao.org

    5、测试cnpm是否安装成功? 命令行: cnpm -v

    6、 全局安装webpack : cnpm(npm) install -g webpack@3

    7、测试webpack是否安装成功? 命令行: webpack -v

  

  //以下步骤每一个项目操作一遍

  //以下操作都必须在!!项目根目录下!!操作

    8、命令行进入项目根目录: 按下shift键的同时,点鼠标右键--->在此处打开命令窗口

    9、

      a、 初始化package.json 文件: npm(cnpm) init [-y]

      b、在本地局部安装webpack : npm(cnpm) install --save-dev webpack@3

      c、在根目录下创建一个webpack.config.js 

        a)//通过require导入所需插件

        var path = require('path');

        //模块导出

        module.exports = {

          //入口

          entry : './src/js/index.js', //相对路径

          //出口

          output : {

            path : path.resolve(__dirname,'dist'),//__dirname是nodeJs中的命令,可以获取当前所在的绝对路径

            filename : "main.js"

          }

        }

        b) 运行: webpack

        c)设置自动监听: webpack --watch

    d、插件

      a) html-webpack-plugin : 自动生成index.html页面

        1> 安装 : npm(cnpm) install --save-dev 插件名

        2> 导入插件

        //webpack.config.js

        //通过require导入所需插件

        var path = require('path');

        var Htmlwebpackplugin = require('html-webpack-plugin');

        //模块导出

        module.exports = {

          //入口

          entry : './src/js/index.js', //相对路径

          //出口

          output : {

            path : path.resolve(__dirname,'dist'),//__dirname是nodeJs中的命令,可以获取当前所在的绝对路径

            filename : "main.js"

          },

          plugins : [

            new Htmlwebpackplugin({template : './src/html/index.html'})

          ]

        }

    e、loader

      a、css-loader style-loader

        a)安装: npm(cnpm) install --save-dev 插件名

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值