JS学习笔记Day26
一、什么是设计模式?
(一)设计模式(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 插件名
JS学习笔记Day26的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Vue.js学习笔记(2)vue-router
vue中vue-router的使用:
- JS 学习笔记--9---变量-作用域-内存相关
JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...
- WebGL three.js学习笔记 使用粒子系统模拟时空隧道(虫洞)
WebGL three.js学习笔记 使用粒子系统模拟时空隧道 本例的运行结果如图: 时空隧道demo演示 Demo地址:https://nsytsqdtn.github.io/demo/sprite ...
- WebGL three.js学习笔记 法向量网格材质MeshNormalMaterial的介绍和创建360度全景天空盒的方法
WebGL学习----Three.js学习笔记(5) 点击查看demo演示 Demo地址:https://nsytsqdtn.github.io/demo/360/360 简单网格材质 MeshNor ...
- WebGL three.js学习笔记 创建three.js代码的基本框架
WebGL学习----Three.js学习笔记(1) webgl介绍 WebGL是一种3D绘图协议,它把JavaScript和OpenGL ES 2.0结合在一起,通过增加OpenGL ES 2.0的 ...
- vue.js 学习笔记3——TypeScript
目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...
- 2019-4-29 js学习笔记
js学习笔记一:js数据类型 1:基本数据类型 number类型(整数,小数) String类型 boolean类型 NaN类型其实是一个nu ...
- 一点感悟:《Node.js学习笔记》star数突破1000+
写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...
随机推荐
- 前端入门21-JavaScript的ES6新特性
声明 本篇内容全部摘自阮一峰的:ECMAScript 6 入门 阮一峰的这本书,我个人觉得写得挺好的,不管是描述方面,还是例子,都讲得挺通俗易懂,每个新特性基本都还会跟 ES5 旧标准做比较,说明为什 ...
- 超大文本文件浏览器Snaptext,支持不限制大小的文本文件浏览
文本文件超过1G就很少有软件可以打开了,超过10G就只有有限的几个可以打开了,那20G.30G.100G呢? Snaptext超大文本浏览器,应该是世界上最快速的文本文件浏览器,它支持基本不限制大小的 ...
- 用npm安装git上的项目
直接通过 git 上项目的地址进行安装npm install git+https://github.com/sunxiaochuan/koatest.git 地址获取如下图:
- TCP点对点转发的实现与原理(nodejs)
Nagent Nagent是TCP点对点转发实现,名称来源于Nat与Agent的组合.类似frp项目,可以在局域网与互联网提供桥梁. 前提是你要有一台流量服务器并且有一个公网IP.如果没有,也可以找服 ...
- Testlink1.9.17使用方法(第二章 登录&汉化设置)
第二章 登录&汉化设置 QQ交流群:585499566 1,使用超级账户admin/admin登录. 2,登录后,会提示创建一个新的项目,先不要创建,先进入用户管理,设置成中文显示,也就是汉化 ...
- pyspider爬网页出现中文乱码的解决办法
为什么会出现乱码呢?按照binux的说法 这就是 lxml 的蛋疼之处,给它 unicode 它有的时候它不认,给它 bytes 它又处理不好 方法1: response.content = (res ...
- Go语言打造以太坊智能合约测试框架(level3)
传送门: 柏链项目学院 第三课 智能合约自动化测试 之前课程回顾 我们之前介绍了go语言调用exec处理命令行,介绍了toml配置文件的处理,以及awk处理文本文件获得ABI信息.我们的代码算是完成了 ...
- windows下编译Grafana前端
本次介绍一下Windows环境源码编译步骤. 准备 安装Go 1.8.1 安装NodeJS LTS 安装Git 安装golang开发环境: 参考链接:https://www.cnblogs.com/ ...
- Python基础之函数和模块
函数的基本使用 函数的定义:把具有独立功能的代码块组织成一个小模块,在需要的时候调用.或者说,函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数的使用:1.定义函数:2.调用函数 ...
- 从输出日志中提取接口的入参和返回做为用例导入到excel中
1 背景 接口用例已经在项目中的yml文件中编写,但是yml文件不能做为交付文档用,本文对工作中从接口输出日志中提取用例信息,并导入到excel文件中做了总些 2 工具 idea,notepad+ ...