Vue

一. Vue 实例

Vue_第1张图片
var app = new Vue({
    el:'#app',
    data:{}
  }
})

以后你可以在 API 参考中查阅到完整的实例属性和方法的列表。

实例生命周期钩子

比如 created 钩子可以用来在一个实例被创建之后执行代码

Vue_第2张图片

二. 模板语法

1. 插值

文本

数据绑定最常见的形式就是使用“Mustache”语法 (双大括号) 的文本插值

原始 HTML
Vue_第3张图片
特性

Mustache 语法不能作用在 HTML 特性上,遇到这种情况应该使用 v-bind 指令

使用 JavaScript 表达式
Vue_第4张图片

2. 指令

Vue_第5张图片
修饰符

修饰符 (modifier) 是以半角句号 . 指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。例如,.prevent 修饰符告诉 v-on 指令对于触发的事件调用 event.preventDefault()

...

在接下来对 v-onv-for 等功能的探索中,你会看到修饰符的其它例子。

三. 计算属性和侦听器

计算属性
Vue_第6张图片
计算属性缓存 vs 方法

我们可以将同一函数定义为一个方法而不是一个计算属性。两种方式的最终结果确实是完全相同的。然而,不同的是计算属性是基于它们的依赖进行缓存的。只在相关依赖发生改变时它们才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。

这也同样意味着下面的计算属性将不再更新,因为 Date.now() 不是响应式依赖:

computed: {
  now: function () {
    return Date.now()
  }
}

相比之下,每当触发重新渲染时,调用方法将总会再次执行函数。
我们为什么需要缓存?假设我们有一个性能开销比较大的计算属性 A,它需要遍历一个巨大的数组并做大量的计算。然后我们可能有其他的计算属性依赖于 A 。如果没有缓存,我们将不可避免的多次执行 A 的 getter!如果你不希望有缓存,请用方法来替代。

计算属性 vs 侦听属性

Vue 提供了一种更通用的方式来观察和响应 Vue 实例上的数据变动:侦听属性。当你有一些数据需要随着其它数据变动而变动时,你很容易滥用 watch——特别是如果你之前使用过 AngularJS。然而,通常更好的做法是使用计算属性而不是命令式的

计算属性的 setter

计算属性默认只有 getter ,不过在需要时你也可以提供一个 setter :

// ...
computed: {
  fullName: {
    // getter
    get: function () {
      return this.firstName + ' ' + this.lastName
    },
    // setter
    set: function (newValue) {
      var names = newValue.split(' ')
      this.firstName = names[0]
      this.lastName = names[names.length - 1]
    }
  }
}
// ...

现在再运行 vm.fullName = 'John Doe' 时,setter 会被调用,vm.firstNamevm.lastName 也会相应地被更新。

侦听器

虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器。这就是为什么 Vue 通过 watch 选项提供了一个更通用的方法,来响应数据的变化。当需要在数据变化时执行异步或开销较大的操作时,这个方式是最有用的。
除了 watch 选项之外,您还可以使用命令式的 vm.$watch API。

四. Class 与 Style 绑定

1. 绑定 HTML Class

在将 v-bind 用于 class 和 style 时,Vue.js 做了专门的增强。表达式结果的类型除了字符串之外,还可以是 对象 或 数组。

对象语法

我们可以传给 v-bind:class 一个对象,以动态地切换 class:

上面的语法表示 active 这个 class 存在与否将取决于数据属性 isActive 的 truthiness。
我们也可以在这里绑定一个返回对象的计算属性。

数组语法

我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:

data: {
  activeClass: 'active',
  errorClass: 'text-danger'
}

渲染为:

如果你也想根据条件切换列表中的 class,可以用三元表达式:

这样写将始终添加 errorClass,但是只有在 isActive 是 truthy[1] 时才添加 activeClass

不过,当有多个条件 class 时这样写有些繁琐。所以在数组语法中也可以使用对象语法:

用在组件上

当在一个自定义组件上使用 class 属性时,这些类将被添加到该组件的根元素上面。这个元素上已经存在的类不会被覆盖。

2. 绑定内联样式

多重值

从 2.3.0 起你可以为 style 绑定中的属性提供一个包含多个值的数组,常用于提供多个带前缀的值,例如:

这样写只会渲染数组中最后一个被浏览器支持的值。在本例中,如果浏览器支持不带浏览器前缀的 flexbox,那么就只会渲染 display: flex

五. 条件渲染

v-else-if

v-else-if,顾名思义,充当 v-if 的“else-if 块”,可以连续使用:

A
B
C
Not A/B/C

类似于 v-elsev-else-if 也必须紧跟在带 v-if 或者 v-else-if 的元素之后。

key 管理可复用的元素

Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染。这么做除了使 Vue 变得非常快之外,还有其它一些好处。

v-show

注意,v-show 不支持