Vue.js 概览
基础
1. 关键语法
2. Vue 实例
生命周期钩子
created: 实例被创建之后
mounted, uodated, destroyed 等,生命周期中的 this 指向 Vue 实例
注意: 不要在钩子函数,选项属性或者回调上使用箭头函数,比如
created: () => console.log(this.a)
或者vm.$watch('a', newValue => this.myMethod())
, 因为箭头函数没有 this,this 就不等于 Vue 实例了
生命周期示例图
3. 模板语法
3.1 插值
文本
双大括号语法用于绑定实例上 data 对象的属性,使用 v-once 执行一次性插值(绑定一次)。
原始HTML 会将数据解释为普通文本,而非 HTML,为了输出真正的 HTML, 需要使用 v-html
HTML特性
语法不能用在 HTML 特性上,这种情况需要使用 v-bind 指令
JavaScript 表达式
模板中可以使用完全的 JavaScript 表达式支持,但是只支持 单个表达式
而且模板表达式只能访问 全局变量的一个白名单,不能够在其中试图访问用户定义的全局变量。
3.2 指令
指令是带有 v-
前缀的特殊属性,指令的预期值是 单个 JavaScript表达式
参数
一些指令能够接受 参数,在指令后面以冒号显示。
如以下的 href 即为参数,表示将元素的 hred 特性与表达式 url 的值绑定。
以下的 click 即为参数,用于监听 DOM 事件
动态参数 (存在一些语法约束)
即可以使用 JavaScript 表达式作为指令的参数
当 Vue 实例的 data 属性中,attributeName 为 href, 则以上代码等同于:
修饰符
修饰符是以 . 指明的特殊后缀,用于支持一个指令以特殊的方式绑定。 如 .prevent 告诉 v-on 指令对于触发的事件调用 event.preventDefault():
3.3 缩写
v-bind
v-on
4. 计算属性与侦听器
4.1 计算属性
为了防止在模板中使用过多的逻辑,因此产生了计算属性
Q&A: 使用计算属性还是方法?
计算属性基于响应式的依赖进行缓存,如果依赖没变化,那么访问计算属性会立即返回之前的结果。而使用方法的化,无论响应式依赖有没有变化,只要重新渲染都是执行方法。
watch 表示侦听属器
略
计算属性的setter
计算属性默认只有 getter,不过在需要时可以提供一个 setter
4.2 侦听器
使用 watch 的语法,可以在数据变化会导致 异步请求 Ajax 或开销较大的操作时 使用。
5. Class 与 Style 绑定
5.1 绑定 Class
通过 v-bind:class 实现,同时 v-bind:class 可以与普通的 class 属性共存。
对象语法
同时绑定的数据对象可以不必内联在模板里,可以来自于 data 属性
或者来自计算属性
数组语法
5.2 绑定 Style
注意绑定 style 里的 css 属性需要使用驼峰式的写法,或者短横线用引号包裹
驼峰式 fontSize
短横线用引号包裹
6. 条件渲染
6.1 v-if
vi-if, v-else, v-else-if 等用于控制是否渲染某个单一元素.
当需要控制是否渲染一组元素时可以使用 进行包裹
使用 key 管理可复用的元素
6.2 v-show
v-show 只是切换元素的 css, display 的值。 v-if 是直接影响 DOM 的渲染。
6.3 v-if vs v-show
略
6.4 v-if 不要与 v-for 一起使用
7. 列表渲染 v-for
v-for 可用于遍历数组与对象,
7.1 数组更新检测
变异方法
Vue 对会改变原数组的数组方法进行了包裹,确保数组的变化会触发视图更新。变异方法包括如下:
非变异方法
即这些方法不会改变原数组,而是产生了新的数组,如 filter(), concat(), slice(),当使用非变异方法时,可以用新数组替换就数组:
注意事项
由于 JavaScript 的限制,Vue 不能检测以下数组的变化:
通过索引直接设置数组元素时:
vm.items[index] = newValue
; (可以通过 Vue.$set() 方法, 通过 splice 方法解决)修改数组的长度是: vm.items.length = newLength;(可以通过 splice(newLength) )
同样由于JavaScript 的限制,Vue 不能检测对象属性的添加和删除,这意味着添加新的属性并不能有响应式的效果。(因此可以使用 Vue.set 来设置新的响应式属性)。
8. 事件处理
8.1 事件修饰符
8.2 按键修饰符
9. 表单输入绑定
https://cn.vuejs.org/v2/guide/forms.html 略
10. 组件基础
组件分为根实例组件与普通组件,
根实例组件需要 el 属性指定挂载的 DOM 节点,普通组件没有 el 属性。 其他的属性如 data, computed, watch,以及生命周期钩子等都是一样的。
区别于根实例组件,一个普通组件的 data 选项必须是一个函数,这样各个组件实例之间才能互相独立。
10.1 组件注册类型
全局注册与局部注册
10.2 父子通信
$emit 与 on
10.3 slot
10.4 动态组件
特殊的 is
深入了解 组件
1. 组件注册
两张组件取名方式:
kebab-case 短横线连线: my-component-name
(推荐方式)
PascalCase 大驼峰式: MyComponentName
1.1 全局注册
1.2 局部注册
即通过 组件(无论是根组件或者是普通组件) 的 components 属性进行注册。
2. Prop
给 prop 传递静态的值
给 prop 动态赋值
2.1 Props 类型验证
略
3. 自定义事件
略
4. 插槽 slot
略
Last updated