Vue.js权威指南

一、遇见Vue.js

1.MVP,从MVC演化而来,Controller/Presenter负责逻辑的处理,完全把View和Model进行了分享,主要的程序逻辑在Presenter里实现,与具体的View是没有直接关联的,而是通过定义好的接口进行交互,从而使得在变更View的时候可以保持Presenter不变

2.MVVM,只是把MVC的Controller和MVP的Presenter改成了ViewModel,View的变化会自动更新到ViewModel,ViewModel的变化也会自动同步到View上显示

二、数据绑定

三、指令

1.指令(Directive)是特殊的带有前缀v-的特性,指令的值限定为绑定表达式,指令的职责就是当其表达式的值改变时把某些特殊的行为应用到DOM上

2.v-if有更高的切换消耗,而v-show有更高的初始渲染消耗。因此,如果需要频繁地切换,使用v-show较好;如果在运行时条件不大可能改变,则用v-if较好

3.v-model指令参数:number,将用户的输入自动转换为Number类型;lazy,将数据改到在change事件中发生;debounce,设置一个最小延迟,在每次敲击之后延时同步输入框的值与数据

4.应该尽量避免直接设置数据绑定的数组元素,因为这些变化 不会被Vue.js检测到,因而也不会更新视图渲染

5.使用v-for,将得到一个特殊的作用域,类似于AngularJS的隔离作用域,需要明确指定props属性传递数据,否则在组件 内将获取不到数据

四、计算属性

  1. 计算属性就是当其依赖属性的值发生变化 时,这个属性的值会自动更新,与之相关的DOM部分也会同步自动更新

五、表单控件绑定

1.多个复选框放入一个数组中

2.当被选中的option有value属性时,vm.selected为对应option的value值;否则为对应option的text值

六、过滤器

1.过滤器,本质上都是函数,作用在于用户输入数据后,它能够进行处理,并返回一个数据结果;过滤器函数将始终以表达 式的值作为第一个参数,带引号的参数会被当作字符串处理,而不带引号的参数会被当作 数据属性名来处理

2.内置过滤器:

字母操作:capitalize、uppercase、lowercase

json过滤器:son

限制:limitBy、filterBy、orderBy处理并返回过滤后的数组

currency过滤器:将数字值转换为货币形式输出

debounce过滤器:延迟处理器一定的时间执行

七、Class与Style绑定

1.可以传给v-bind:class一个对象,以动态地切换class,v-bind:class指令可以与普通的class特性共存

2.v-bind:style绑定内联css

八、过滤

1.transition特性可以与这些资源一起搭配使用:v-if、v-show、v-for、动态组件

2.内置Class类名:.xxx-transition、.xxx-enter、.xxx-leave

3.只使用js钩子时,为js过渡显式声明css:false,Vue.js将跳过CSS检测,这样也会防止css规则对过渡的干扰

九、Method

1.所有的Vue.js事件处理方法和表达式都严格绑定在当前视图的ViewModel上

2.需要注意:

  • methods中定义的方法内的this始终指向创建的Vue实例

  • 与事件绑定的方法支持参数event即原生DOM事件的传入

  • 方法在普通元素上时,只能监听原生DOM事件;用在自定义元素组件上时,也可以监听子组件触发的自定义事件

3.四个事件修饰符:.prevent、.stop、.capture、.self

十、Vue实例方法

1.组件树访问:$parent、$root、$children、$refs

2.DOM访问:$el、$els

3.数据访问:$data、$options

4.实例方法:$appendTo()、$before()、$after()、$remove()、$nextTick()

5.实例event方法:$on()、$once()、$emit()、$dispatch()、$broadcast()、$off()

十一、组件

1.Vue.js的组件可以理解为预先定义好行为的ViewModel类,一个组件可以预定义很多选项,但最核心的:

模板(template)、初始数据(data)、接受的外部参数(props)、方法(methods)、生命周期钩子函数(lifecycle hooks)

2.props是组件数据的一个字段,期望从父组件传下来数据,组件的作用域是孤立的,意味着不能并且不应该在子组件的模板内直接引用父组件的数据,所以子组件需要显式地用props选项来获取父组件的数据

3.组件通信:this.$parent、this.$children、this.$root,不过子组件应当避免直接依赖父组件的数据,尽量显式地使用props传递数据,在子组件中修改父组件的状态是非常糟糕的做法,会导致父子紧密地耦合,很难理解父组件的状态

4.solt作为原始内容的插槽,父组件的内容将被抛弃,除非子组件模板包含<slot>,标签的内容视为回退内容,回退内容在子组件的作用域内编译,当宿主元素为空并且没有内容插入时显示这个回退内容

5.混合以一种灵活的方式为组件提供分布利用的功能,混合对象可以包含做任意的组件选项,当组件使用了混合对象时,混合对象的所有选项将被“混入”组件自己的选项中

6.生命周期:init、created、beforeCompile、compiled、ready、attached、detached、beforeDestory、destroyed

十二、表单校验

1.vue-validator

2.v-validate指令语法:v-validate[:field]=“array literal | object literal | binding”

3.内置验证规则:required、pattern、minlength、maxlength、min、max

4.v-validate所在元素,可以监听的事件:valid、invalid、touched、dirty、modified

十三、与服务端通信

1.vue-resource

2.vue-async-data,是一个异步加载数据状态指示的插件,本身并不支持异步获取服务端数据的功能,仅仅指示数据目前是处于加载 状态还是已经加载完毕

十四、路由与视图

1.vue-router

2.vue-router钩子函数:canReuse、canActivate、activate、data、canDeactivate、deactivate

十五、vue-cli

1.快速生成一个基于Webpack构建的项目:vue init webpack my-project

2.支持的命令:vue init <template-name><project-name>;vue list;

十六、测试开发与调试

1.ESLint

2.工具包:eslint-loader、eslint-friendly-formatter、eslint-config-standard、eslint-plugin-html

3.开发工具:Vue Syntax Highlight、Snippets(sublime)、VUe.js(WebStorm)、Vue(Visual Studio Code)

4.调试工具:Chrome——Vue.js devtools

十七、Scrat+Vue.js的化学反应

1.前端工程化:开发规范、模块化、组件化、组件库、性能优化、项目部署、开发流程、工程工具

2.Scrat是UC团队在百度的FIS基础上二次开发的webapp模块化开发框架,最大的特色是模块化开发和模块生态,理念是像搭积木一样开发和维护系统,通过组装模块得到一个完整的系统

十八、Vue.js2.0

1.Virtual DOM:通过JS对象表示的树结构来构建一棵真正的DOM树,当数据状态发生变化时可以直接修改这个JS对象,接着对比修改后的JS对象,记录下需要对页面做的DOM操作,然后将其应用到真正的DOM树,实现视图的更新,这个过程就是Virtual DOM的核心思想

2.服务端渲染优势:首屏渲染速度更快、SEO、减少HTTP请求

十九、源码篇——util

1.env:

  • 系统判断:inBrowser、isIE9、isAndroid、isIos、isWechat

  • 属性支持:hasProto

  • 过滤属性:transitionPrep、transitionEndEvent、animationProp、animationEndEvent

2.dom:

  • dom操作:query、inDoc、before、after、prepend、extractContent、remove、replace、trimNode、isTemplate、isFragment、getOuterHTML

  • 属性操作:getAttr、getBindAttr、hasBindAttr

  • class操作:setClass、addClass、removeClass

  • 事件操作:on、off

  • 其他:cateAnchor、findRef、mapNodeRange、removeNodeRange

3.lang:

  • 对象操作:set、del、hasOwn、extend、isObject、isPlainObject、def

  • 名称转换:classify、hyphenate、camelize

  • 数组操作:indexOf

  • 类型转换:_toString、toNumber、toBoolean、toArray

  • 方法绑定:bind

  • 其他:debounce、stripQuotes、cancellable、looseEqual、isLiteral、isReserved

4.components:commonTagRe、reservedTagRe、checkComponentAttr

5.options:mergeOptions、resolveAsset

6.debug:warn

二十、源码篇——深入响应式原理

二十一、源码篇——父子类合并策略

二十二、源码篇——缓存

  1. Cache类:put、shift、get

二十三、源码篇——props

二十四、源码篇——events

二十五、Webpack

二十六、Rollup

二十七、Browserify

二十八、vue-loader

二十九、PostCSS

三十、扩展篇

(0)

相关推荐

  • Vue面试题之vue实现MVVM数据绑定

    MVVM 什么是MVVM? MVVM是Model-View-ViewModel,是把一个系统分为了模型(model).视图(view)和view-model三个部分.vue是一个典型的MVVM思想,数 ...

  • Vuejs计数器及MVVM

    4.Vue.js计数器 计数器小案例点击加号加1,点击减号按钮就会减1 运行结果如下: 由于当前计数这四个字是不变的,所以可以直接写在div中 现在基本的样式就写完了,接下来该让按钮有效果了 思路分析 ...

  • Vue.js 学习教程指南

    腾讯技术工程已认证的官方帐号取消关注275 人赞同了该文章作者:@被删分享一本腾讯工程师写的 <深入理解Vue.js实战>书.该书主要介绍了作者这些年来使用 Vue.js框架.前端开发的一 ...

  • 人工湿地水质净化技术权威指南来了,请注意查收!

    近年来,人工湿地技术在水环境治理和修复中的大量应用,尤其是在污水处理厂尾水净化.微污染水体净化.农田退水及类似低浓度废水的净化处理方面.为进一步加强水生态环境保护修复,促进区域再生水循环利用,指导各地 ...

  • 从权威指南共识窥探:不同病因慢性便秘的治疗策略

    在饮食结构.生活节奏和社会心理等因素影响下,我国当前各年龄段成人慢性便秘的发病人数越来越多,患病率高达16%~20%1,尤其是老年便秘患者,患病率可达50%2,且随着年龄的增长,发病率也随之攀升,严重 ...

  • 超50%的肺癌患者术后2年遭遇复发转移,权威指南教你降低风险!

    近年来,肺癌在筛查.手术.放化疗.靶向治疗以及免疫治疗等各个方面都取得了重大进展,但手术仍是目前非小细胞肺癌(NSCLC)首选的治疗方法,只有接受了根治性手术才有彻底治愈的可能. 然而,遗憾的是,只有 ...

  • 7个实用的 Vue.js 工具和库

    前端技术优选 昨天 以下文章来源于前端迷社区 ,作者小迷妹 大家好,我是为前端娱乐圈操碎了心的小迷妹,正宗前端开发一枚,每天推荐一个小工具/源码,装满你的收藏夹,每天分享一个小技巧,让你轻松节省开发效 ...

  • 厉害了我的咖啡!权威指南强烈推荐饮用咖啡来降低肝癌发生风险

    "咖啡致癌"这个说法仍然在流传,也有不少朋友犹豫是否要在略带困意的午后呷上几口咖啡. 事实证明,这个说法其实是炒了很多年前的一个冷饭.最新的研究结论是咖啡不存在致癌危险性,世界卫生 ...

  • vue.js的安装

    公司要开始分配给我做前后端分离项目了555555555555 让我一个java的去了解vue并且还要会搭建=-= 莫得办法那么就开始必不可少的安装环节吧: 第一步! 安装node.js: 首先进入官网 ...

  • .net core3.1 webapi + vue.js + axios实现跨域

    我所要讲述的是,基于.net core3.1环境下的webapi项目,如何去使用axios对接前端的vue项目 既然谈到axios,这里贴出axios的官方文档地址: http://www.axios ...

  • 写一手好字能多得20分!小学阶段如何教孩子练字,送你一篇权威指南!

    家教 练一手好字吧 俗话说,"字如其人".虽然一个人字写得好不好,并不代表他是个什么样的人,但不得不承认:写字好看的人,永远能比别人多一些机会. 学生时代的加分项:老师会再三叮嘱, ...