• vue组件生命周期


    分为4个阶段:
    create/mount/update/destroy
      每一个阶段都对应着有自己的处理函数
        create: beforeCreate created
      初始化
        mount: beforeMount mounted
      和挂载相关的处理
        update: beforeUpdate updated
      根据要更新的数据 做逻辑判断
        destroy:beforeDestroy destroyed
      清理工作

    <!doctype html>
    <html>
     <head>
      <meta charset="UTF-8">
      <title>生命周期</title>
        <script src="js/vue.js"></script>
     </head>
     <body>
      <div id="container">
            <p>{{msg}}</p>
    <!--点击的时候isShow进行取反  -->
            <button @click="isShow = !isShow">切换是否显示组件</button>
            <my-component v-if="isShow"></my-component>
        </div>
        <script>
            Vue.component("my-component",{
                template:`
                        <div>
                            <button @click="handleClick">Click Me</button>
                            <h1>component:{{count}}</h1>
                            </div>
                `,
                data:function(){
                        return {
                            count:0
                        }
                    },
                methods:{
                    handleClick:function(){
                        this.count++;
                    }
                },
                beforeCreate: function () {
                console.log('准备创建组件');
            },
            created: function () {
                console.log('组件创建完毕');
            },
            beforeMount: function () {
                console.log('组件的模板准备挂载到DOM');
            },
            mounted: function () {
                console.log('挂载完毕');
            },
            beforeUpdate: function () {
                console.log('准备更新了');
            },
            updated:function(){
                console.log('更新完成');
            },
            beforeDestroy: function () {
                console.log('准备destroy');
            },
            destroyed: function () {
                console.log('destroy完成');
            }
            })
            new Vue({
                el:"#container",
                data:{
                    msg:"Hello VueJs",
                    isShow:true
                }
            })
        </script>
     </body>
    </html>

     生命周期练习,需要那阶段写那个阶段

    <!doctype html>
    <html>
     <head>
      <meta charset="UTF-8">
      <title>生命周期练习</title>
        <script src="js/vue.js"></script>
     </head>
     <body>
      <div id="container">
            <p>{{msg}}</p>
            <my-component></my-component>
        </div>
        <script>
            Vue.component("my-component",{
                data:function(){
                    return {
                        myOpacity:0
                    }
                },
                template:` <h1 v-bind:style="{opacity:myOpacity}">透明度将改变
                </h1>`,
                mounted:function(){
                    setInterval(function(){
                        this.myOpacity += 0.1;
                        if(this.myOpacity>1){
                            this.myOpacity = 0;
                        }
                    }.bind(this),1000)
                }
            })
            new Vue({
                el:"#container",
                data:{
                    msg:"Hello VueJs"
                }
            })
        </script>
     </body>
    </html>
  • 相关阅读:
    对linux内核创建flash上的各分区源码进行分析
    如何调试ubifs文件系统
    如何打开linux内核中dev_dbg的开关
    配置linux内核输出所有的log信息
    uboot向linux传递输出任何log信息的方法
    redis:Invalid input of type: 'bool' type. Convert to a byte,string or number first
    dd命令参数解析
    shell脚本中使用什么工具进行计算
    openwrt的编译方法
    bootstraptable表格columns 隐藏方法
  • 原文地址:https://www.cnblogs.com/wangruifang/p/7768137.html
Copyright © 2020-2023  润新知