圖中紅色標紅的函數html
created() {
}
mounted() {
}
複製代碼
生命週期函數中的this默認綁定到該vue實例,因此不要使用箭頭函數,會出現this綁定錯誤。vue
<div id="app">hello world</div>
var vm=new Vue({
el:'#app',
template:'<div>hello vue</div>'
data:{
a:1
},
beforeCreate() {
console.log('beforeCreate') // beforeCreate
console.log(this) // Vue$3
console.log(this.$el) // undefined
console.log(this.a) // undefined
}
})
複製代碼
beforeCreate(): 可獲取vue實例,data數據未綁定,el未掛載。因此不要在此函數內對數據作任何修改,由於數據undefined。
<div id="app">hello world</div>
var vm=new Vue({
el:'#app',
template:'<div>hello vue</div>'
data:{
a:1
},
created() {
console.log('created') // created
console.log(this) //Vue$3
console.log(this.$el) // undefined
console.log(this.a) // 1
}
})
複製代碼
created(): 數據已掛載,el未掛載,適合初始化數據。
el
屬性var vm=new Vue({
data:{
a:1
},
beforeMount() {
console.log('beforeMount') // 沒有任何輸出
}
})
vm.$mount('#app')
// beforeMount
複製代碼
template
屬性var vm=new Vue({
el:'#app',
data:{
a:1
},
beforeMount() {
console.log('beforeMount') // beforeMount
console.log(this) // Vue$3
console.log(this.$el) // <div id="app">hello world</div>
console.log(this.a) // 1
}
})
複製代碼
3. 有
template
屬性
var vm=new Vue({
el:'#app',
template:'<div>hello vue</div>'
data:{
a:1
},
beforeMount() {
console.log('beforeMount') // beforeMount
console.log(this.$el) // 注意!! <div id="app">hello world</div>
}
})
複製代碼
beforeMount: 渲染template,但el仍未掛載
var vm=new Vue({
el:'#app',
template:'<div>hello vue</div>'
data:{
a:1
},
mounted() {
console.log('mounted') // mounted
console.log(this.$el) // 注意!! <div>hello vue</div>
}
})
複製代碼
mounted(): 掛載el,將el標識的dom元素整個替換成template渲染成的dom元素。
var vm=new Vue({
el:'#app',
template:'<div>hello vue</div>',
data:{
a:1
},
beforeUpdate() {
console.log('beforeUpdate')
},
updated() {
console.log('updated')
}
})
vm.a=2 // 沒有任何輸出
var vm=new Vue({
el:'#app',
template:'<div>hello vue!!!{{a}}</div>',
data:{
a:1
},
beforeUpdate() {
console.log('beforeUpdate')
},
updated() {
console.log('updated')
}
})
vm.a=2 // beforeUpdate updated
複製代碼