Vuejs vm对象详解

vue数据是怎么驱动视图的?
一堆数据放在那里是不会有任何作用的,它必须通过我们的View Model(视图模型)才能操控视图。

图中的model其实就是数据,一般我们写成js对象的格式;

中间的这个所谓View Model,就是

var vm = new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!'
  }
})

我们把数据放到了vm里,然后把各种directive放到视图里,这样我们就可以以vm为媒介,通过改变数据来改变视图。

vm这个对象有哪些属性和方法

我们看到

var vm = new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!'
  }
})

误区

vm实际上是Vue这个类的一个实例,非常容易混淆的是,你会很容易的以为

vm.el == '#app';
vm.data== {
  message: 'Hello Vue!'
};
vm.data.message =='Hello Vue!';

实际上这都是错误的,

var vm = new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!'
  }
})

这只是传进 Vue()的一个参数,它可不是vm本身。

通过vm读取数据

实际上,vm.messasge == ‘Hello Vue!’, vm的属性是直接跟数据的key绑定的(至于怎样绑定的现在不用管),这是一种代理属性;

这个数据是响应式(reactive)的

var data = { a: 1 }
var vm = new Vue({
data: data
})
vm.a === data.a // -> true

// 设置vm数据会使原来的数据发生改变

vm.a = 2
data.a // -> 2
// ... 反过来亦然
data.a = 3
vm.a // -> 3

怎么通过vm获取其他属性

vm.el == '#app';
vm.data== {
  message: 'Hello Vue!'
};
vm.data.message =='Hello Vue!';

以上虽然是错误的写法,有时候我们还是希望获得这些属性的,通过vm你需要这样写:

vm.$el === document.getElementById('app') // -> true
vm.$data === data // -> true
vm.$data.message ==='Hello Vue!' // -> true

这个$符代表的就是vm的真实属性了。

详细其他属性的请查阅文档Api

不仅有属性,还有方法

vm.$watch(‘a’, function (newVal, oldVal) {
// 当vm.a发生改变的时候,这个回调函数将会被触发
})
详细其他方法,请查阅文档Api

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值