Vue的生命周期钩子

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <div id="app">
      <App></App>
    </div>

    <script src="node_modules/vue/dist/vue.js"></script>
    <script>
      Vue.component('Test', {
        data() {
          return {
            msg: 'hello world',
            data: {}
          };
        },
        template: `
          <div>
            <h2>{{msg}}</h2>  
            <button @click="clickHandler">改变</button>
          </div>
        `,
        methods: {
          clickHandler() {
            this.msg = 'hello Vue';
          }
        },
        beforeCreate() {
          // 组件创建之前
          console.log(this); // 实例被创建
          console.log(this.msg); // 数据未拿到 undefined
        },
        created() {
          // 组件创建之后
          // 可以操作后端数据,数据驱动视图
          // 应用:ajax请求
          // $.ajax({
          //   type:'get',
          //   url:'',
          //   success:(data)=>{
          //     this.data = data;
          //   }
          // });
          console.log(this.msg); // hello world
        },
        beforeMount() {
          // 挂载数据到DOM之前调用
          console.log(document.getElementById('app'));
        },
        mounted() {
          // 挂载数据到DOM之后调用
          console.log(document.getElementById('app'));
        },
        beforeUpdate() {
          // 更新DOM之前,获取原始DOM
          console.log(document.getElementById('app').innerHTML);
        },
        updated() {
          // 更新DOM之后,获取最新DOM
          console.log(document.getElementById('app').innerHTML);
        },
        beforeDestroy() {
          console.log('beforeDestroy');
        },
        destroyed() {
          console.log('destroyed');
        },
        activated() {
          console.log('组件被激活了');
        },
        deactivated() {
          console.log('组件被停用了');
        }
      });
      var App = {
        data() {
          return {
            isShow: true
          };
        },
        template: `
          <div class="app">
            <!-- 失活的组件将会被缓存!防止重复渲染-->
            <keep-alive>
              <Test v-if="isShow" />
            </keep-alive>
            <button @click="isShow = !isShow">改变生死</button>
          </div>
        `
      };
      new Vue({
        el: '#app',
        data() {
          return {};
        },
        components: {
          App
        }
      });
    </script>
  </body>
</html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值