首页 > 代码库 > vue爬坑之路2
vue爬坑之路2
构造器
每个vue.js应用都是通过构造函数Vue穿件一个Vue的根实例启动的:
var vm = new Vue({
//选项
})
在实例化Vue时,需要传入一个选项对象,他可以包含数据,模板,挂在元素,方法,生命周期钩子等选项。
vue构造器是可扩展的,实际上,所有的vue.js组件其实都是被扩展的vue实例。
var MyComponent = Vue.extend({
//扩展选项
})
//所有的’MyComponent‘实例都将以预定义的扩展选项被创建
var myComponentInstance = new MyComponent();
属性与方法
每个Vue实例都会代理七data对象里所有的属性:
var data = http://www.mamicode.com/{a:1};
var vm = new Vue({
data:data
});
vm.a===data.a;// ->true
//设置属性也会影响到原始数据
vm.a = 2;
data.a ;// ->2
//反之亦然
data.a = 3;
vm.a; //->3
注意只有这些被代理的属性是响应的。如果在实例创建之后添加新的属性到实例上,它不会触发视图更新。
除了data属性,Vue实例暴露了一些有用的实例属性。这些属性与方法都有前缀$,以便于与代理的data属性区分。例如:
var data = http://www.mamicode.com/{a:1};
var vm = new Vue({
el:‘#example‘,
data:data
})
vm.$data =http://www.mamicode.com/== data //->true
vm.$el === document.getElementById(‘example‘) // ->true
//$watch是一个实例方法
vm.$watch(‘a‘,function(newVal,oldVal){
//这个回调将在‘vm.a‘改变后调用
})
注意,不要在实例属性或者回调函数中(如vm.$watch(‘a‘,newVal => this.myMethond()))使用箭头函数。因为箭头函数绑定父上下文,所以this不会像预想的一样是Vue实例,而是this.myMethod未被定义。
实例生命周期
每个Vue实例在被创建之前都要经过一系列的初始化过程。例如,实例需要配置数据观测(data observer)、编译模板、挂在实例到DOM,然后在数据变化时更新DOM。在这个过程中,实例也会调用一些生命周期钩子,这就给我们提供了执行自定义逻辑的机会。例如,created这个钩子在实例被创建之后调用:
var vn = new Vue({
data:{
a:1
},
created: function (){
//this 指向 vm实例
console.log(‘a is‘+this.a)
}
}) // ->‘a is: 1‘
Vue.js是否有‘控制器’的概念?答案是:没有。
所谓“生命周期”,就是在类实例化的过程中,构造函数执行的不同阶段。
“钩子”就是在某个阶段给你一个做某些处理的机会,当做回调函数就行。
vue爬坑之路2