参考书籍《Vue.js快跑:构建触手可及的高性能Web应用》第1章 Vue.js基础-----1-19自定义指令
<!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>