一、什么是Vue.js前端
Vue是一套用于构建用户界面的渐进式的JavaScript框架。vue
二、Vue.js的优势webpack
三、为何要使用Vue.jsweb
随着前端技术的不断发展,前端开发可以处理的业务愈来愈多,网页也变得愈来愈强大和动态化,这些进步都离不开JavaScript。在目前的开发中,已经把不少服务端的代码放到了浏览器中来执行,这就产生了成千上万行的JavaScript代码,他们链接着各式各样的HTML和CSS文件,可是缺少正规的组织形式。这也是为何愈来愈多的前端开发者使用JavaScript框架的缘由,目前比较流行的前端框架有Angular、Reac、Vue等。算法
Vue是一款友好的、多用途且高性能的JavaScript框架,它可以帮助你建立可维护性和可测试性更强的代码库。Vue是渐进式的JavaScript框架,也就是说,若是你已经有了现成的服务端应用,你能够将Vue做为该应用的一部分嵌入其中,带来更加丰富的交互体验。或者若是你但愿将更多业务逻辑放到前端来实现,那么Vue的核心库及其生态系统也能够知足你的各式需求。设计模式
和其余框架同样,Vue容许你将一个网页分割成可复用的组件,每一个组件都包含属于本身的HTML、CSS、JavaScript,以用来渲染网页中相应的地方。若是咱们构建了一个大型的应用,可能须要将东西分割成为各自的组件和文件,使用Vue的命令行工具,使快速初始化一个真实的工程变得很是简单。浏览器
vue init webpack my-project
咱们甚至可使用Vue的单文件组件,它包含了各自的HTML、JavaScript以及带做用域的CSS或SCSS。缓存
MVC(Model-View-Controller)是最多见的软件架构之一,在软件开发领域有着普遍的应用,MVC自己是比较好理解的,可是要讲清楚由它衍生出来的MVP和MVVM就不太容易了。前端框架
4.一、MVC架构
MVC的意思是,能够将软件分为三个部分:
各部分之间的通讯方式为:
而且全部的通讯都是单向的,以下图所示:
MVC 模式的执行流程是有两种方式:
(1)经过View接受指令,传递给Controller
(2)直接经过Controller接受指令
实际项目中每每采用更加灵活的方式:
(1)用户能够向View发送指令(DOM事件),再由View直接要求Model改变状态;
(2)用户也能够直接向Controller发送指令(改变URL触发hashChange事件),再由Controller发送给view ;
(3)Controller很是薄,只起到路由的做用,而View很是厚,业务逻辑都部署在View,因此有些框架里就直接取消了Controller,只保留一个Router(路由器)。
如图所示:
4.二、MVP
MVP(Model-View-Presenter),是从经典的MVC演变而来的。Mode提供数据,View负责显示,Presenter负责逻辑的处理。
MVP和MVC有着一个重大的区别:
如图所示:
4.三、MVVM
MVVM(Model-View-ViewModel),它本质上是MVC的改进版,是针对MVC中的View进行了更细致的分工。ViewModel将视图UI和业务逻辑分开,它能够取出Model的数据,同时帮助处理View中因为须要展现内容而设计到的业务逻辑。
MVVM模式与MVP模式相似,惟一的区别是,它采用了数据双向绑定(data-binding),即View的变更自动反应在ViewModel,反之亦然。
什么是数据驱动
数据驱动是Vue.js最大的特色。在vue中,所谓的数据驱动就是当数据发生变化时,用户界面发生相应的变化,开发者不须要手动的去修改DOM。
好比,咱们点击一个button,须要元素的文本作一个 “是/否” 的切换操做,在传统的jQuery中,对于页面修改的流程一般是:对button绑定事件,而后获取文案对应元素的dom对象,最后根据切换来修改dom对象的文本值。
Vue实现数据驱动
vue实现数据双向绑定主要采用数据劫持,配合发布者-订阅者模式的方式,经过 Object.defineProperty()
来劫持各个属性的 setter
和 getter
,在数据变更时发布消息给订阅者,触发相应监听回调。
当一个普通 JavaScript 对象传给 Vue 实例来做为它的 data 选项时,vue 将遍历它的属性,用 Object.defineProperty 将它们转为 getter/setter 。用户看不到 getter/setter ,可是在内部它们让vue追踪依赖,在属性被访问和修改时通知变化。
vue的数据双向绑定将MVVM做为数据绑定的入口,整合Observer、Compile和Watcher三者,经过Observer来监听本身的Model的数据变化,经过Compile来解析编译模板指令(vue中用来解析{{}}模板语法),最终利用Watcher搭起Observer和Compile之间的通讯桥梁,达到 数据变化 —> 视图更新;视图交互变化(input)—> 数据model变动 双向绑定效果。
getter和setter的理解
当打印出vue实例下的data对象里的属性,它的每一个属性都有两个对应的get和set方法。顾名思义,get为取值方法,set为赋值方法。正常状况下,取值和赋值是用 obj.prop 的方式,可是这样作有一个问题,咱们如何知道对象的值改变了?
咱们能够把get和set理解为function,当咱们调用对象的属性时,会进入到 get.属性(){...} 中,先判断对象是否有这个属性,若是没有,那么就添加一个name属性,并给它赋值;若是有name属性,那么就返回name属性。能够把get当作一个取值的函数,函数的返回值就是它拿到的值。
当给实例赋值时,会进入 set.属性(val){...} 中,形参val就是赋给属性的值,在这个函数里作了不少事情,好比双向绑定等等。由于这个值每次都要通过set,其余方式没法对该值作修改。在ES5中,对象原型有两个属性,_defineGetter_
和 _defineSetter_
,专门用来给对象绑定get和set。
6.1 什么是虚拟DOM
在Vue.js 2.0版本中引入了 Virtual DOM 的概念,Virtual DOM 其实就是一个以JavaScript对象(VNode节点)做为基础来模拟DOM结构的树形结构,这个树形结构包含了整个DOM结构的信息。简单来讲,能够把Virtual DOM理解为一个简单的JS对象,而且最少包含标签名(tag)、属性(attrs)和子元素对象(children)三个属性。不一样的框架对这三个属性的命名会有所差异。
6.2 虚拟DOM的做用
虚拟DOM的最终目标是将虚拟节点渲染到视图上。可是若是直接使用虚拟节点覆盖旧节点的话,会有不少没必要要的DOM操做。例如,一个ul标签下有不少个li标签,其中只有一个li标签有变化,这种状况下若是使用新的ul去替代旧的ul,会由于这些没必要要的DOM操做而形成性能上的浪费。
为了不没必要要的DOM操做,虚拟DOM在虚拟节点映射到视图的过程当中,将虚拟节点与上一次渲染视图所使用的旧虚拟节点作对比,找出真正须要更新的节点来进行DOM操做,从而避免操做其余不须要改动的DOM元素。
其实,虚拟DOM在Vue.js中主要作了两件事情:
6.3 为何要使用虚拟DOM