zoukankan      html  css  js  c++  java
  • 参考书籍《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>
  • 相关阅读:
    【转】Git: There is no tracking information for the current branch.
    【转】git多个远程仓库
    【转】python批量快速合并excel文件
    【转】HTML5-postMessage实现跨域
    Python3正则表达式search和findall差异讨论
    Python Segmentation fault错误定位办法
    Python3压缩和解压缩实现
    Python3+profile性能分析
    案例:ADG环境遇到redo日志member路径有误以及RMAN-6571错误
    CentOS7的udev的绑定规则
  • 原文地址:https://www.cnblogs.com/cuilichao/p/14931443.html
Copyright © 2011-2022 走看看