<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>生命周期钩子</title>
<!--
beforeCreate: 在实例初始化前被触发。
created: 会在实例初始化之后、被添加到DOM之前触发。
beforeMount: 会在元素已经准备好被添加到DOM,但还没有添加的时候触发。
mounted: 会在元素创建后触发(但并不一定已经添加到了DOM,可以用nextTick来保证这一点)。
beforeUpdate: 会在由于数据更新将要对DOM做一些更改时触发。
updated: 会在DOM的更改已经完成后触发。
beforeDestroy: 会在组件即将被销毁并且从DOM上移除时触发。
destroyed: 会在组件被销毁后触发。
-->
</head>
<body>
<div id="app">
<p v-blink>一闪一闪亮晶晶</p>
</div>
<script src="https://unpkg.com/vue"></script>
<script>
// Vue.directive()注册一个全局指令。需要传入指令的名字,以及一个包含钩子函数的对象,这些钩子函数会在设置了该指令的元素的生命周期的各个阶段运行。
// 一共有5个钩子函数,分别是bind、inserted、update、componentUpdated和unbind
// bind钩子函数会在指令绑定到元素时被调用。
// inserted钩子会在绑定的元素被添加到父节点时被调用。
// update钩子会在绑定该指令的组件节点被更新时调用,但是该组件的子组件可能此时还未更新。
// componentUpdated钩子和updated钩子类似,但它会在组件的子组件都更新完成后调用。
// unbind钩子用于指令的拆除,当指令从元素上解绑时会被调用。
Vue.directive('blink', {
bind(el) {
let isVisible = true;
setInterval(() => {
isVisible = !isVisible;
el.style.visibility = isVisible ? 'visible' : 'hidden';
}, 1000)
}
})
let vue = new Vue({
el: "#app",
data: {
count: 0
}
})
</script>
</body>
</html>