zoukankan      html  css  js  c++  java
  • 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>
  • 相关阅读:
    11.json
    10.正则表达式
    9.面向对象、类
    bzoj 2878: [Noi2012]迷失游乐园
    bzoj 2727: [HNOI2012]双十字
    bzoj 3224: Tyvj 1728 普通平衡树
    bzoj 3932: [CQOI2015]任务查询系统
    bzoj 1997: [Hnoi2010]Planar
    4 Django简介
    3 web框架
  • 原文地址:https://www.cnblogs.com/wangruifang/p/7768137.html
Copyright © 2011-2022 走看看