Vue.js 2.0版升级,更改了好多方法或指令
new Vue({ el:'#demo', data:{ msg:"vue2.0" } })
v-model
lazy number debounce (2.0版废弃) 新加 lazy
<input v-model.lazy="msg" />
v-for
v-for
迭代语法变化
-
丢弃
和$index
$key
-
新数组语法
-
value in arr
-
(value, index) in arr
-
-
新对象语法
-
value in obj
-
(value, key) in obj
-
(value, key, index) in obj
-
value 值 key 键 index 索引下标
<li v-for="item in items">{{item.id}}</li>
<li v-for="(value,key) in items">{{value.id}}--{{key}}</li>
<li v-for="(value,key,index) in items">{{value.id}}--{{key}}--{{index}}</li>
每个 Vue 实例都会代理其 data
对象里所有的属性:
var tie = { a: 1 } var vm = new Vue({ data: tie }) vm.a === tie.a // -> true // 设置属性也会影响到原始数据 vm.a = 2 tie.a // -> 2 // ... 反之亦然 tie.a = 3 vm.a // -> 3
除了 data 属性, Vue 实例暴露了一些有用的实例属性与方法。这些属性与方法都有前缀 $,以便与代理的 data 属性区分。例如: var data = { a: 1 } var vm = new Vue({ el: '#example', data: data }) vm.$data === data // -> true vm.$el === document.getElementById('example') // -> true // $watch 是一个实例方法 vm.$watch('a', function (newVal, oldVal) { // 这个回调将在 `vm.a` 改变后调用 }) 注意,不要在实例属性或者回调函数中(如 vm.$watch('a', newVal => this.myMethod()))使用箭头函数。因为箭头函数绑定父上下文,所以 this 不会像预想的一样是 Vue 实例,而是 this.myMethod 未被定义。