vue-cli使用, Vue组件生命周期

基本的命令

npm config set registry https://registry.npm.taobao.org
npm install -g @vue/cli
vue create my-app
cd my-app
npm run serve

如果版本不对, 重新安装nodejs
https://cdn.npm.taobao.org/dist/node/v14.2.0/node-v14.2.0-x64.msi

删掉这些这个文件夹 %userprofile%\AppData\Roaming\npm
参考官方网站:
https://cli.vuejs.org/zh/guide/installation.html

webstorm激活不了?
链接: https://pan.baidu.com/s/1TiRv0KlzRa7-w5gLPzZlWw 提取码: aa77

image.png

创建个组件测试:
src\components\TodoItem.vue

<template>
    <li class="item">{{item}}</li>
</template>

<script>
    export default {
        props: ['item'],
        name: "TodoItem",
        beforeCreate() {
            console.log("子组件beforeCreate");
        },
        created() {
            console.log("子组件Created");
        },
        beforeMount() {
            console.log("子组件beforeMount");
        },
        mounted() {
            console.log("子组件mounted");
        },
        beforeUpdate() {console.log("子组件beforeUpdate");},
        updated() {console.log("子组件updated")},
        beforeDestroy() {console.log("子组件beforeDestroy")},
        destroyed() {console.log("子组件destroyed")}
    }
</script>

<style scoped>
    .item {color: red;}
</style>

src\App.vue

<template>
  <div id="app">
    {{msg}}
    <div>
      <input type="text" v-model="info">
      <button v-on:click="handleClick">添加</button>
    </div>
    <ul>
      <todo-item v-for="item in list" :key="item" :item="item"></todo-item>
    </ul>
  </div>
</template>

<script>
// import HelloWorld from './components/HelloWorld.vue'
import TodoItem from "./components/TodoItem";

export default {
  name: 'App',
  components: {
    TodoItem,  // 注册依赖的组件
  },
  data() {
    return {
      msg: "Hello geektime",
      info: '',
      list: [ "Initial line" ],
    }
  },
  methods: {
    handleClick() {
      this.list.push(this.info);
      this.info = '';
    }
  },
  beforeCreate() {console.log("父组件beforeCreate");},
  created() {console.log("父组件Created");},
  beforeMount() {console.log("父组件beforeMount");},
  mounted() {console.log("父组件mounted");},
  beforeUpdate() {console.log("父组件beforeUpdate");},
  updated() {console.log("父组件updated")},
  beforeDestroy() {console.log("父组件beforeDestroy")},
  destroyed() {console.log("父组件destroyed")}
}
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

效果如下:


image.png
image.png

创建的时候,子组件创建过程,夹在父组件的 beforeMount, mounted之间。

这个示例代码不能说明销毁的场景:
我这样改一下:
把以前的App.vue里面的内容都拿出来作为父组件Panel.vue,App.vue中引入Panel.vue

  • Panel.vue
<template>
    <div class="panel">
        {{msg}}
        <div>
            <input type="text" v-model="info">
            <button v-on:click="handleClick">添加</button>
        </div>
        <ul>
            <todo-item v-for="item in list" :key="item" :item="item"></todo-item>
        </ul>
    </div>
</template>

<script>
    // import HelloWorld from './components/HelloWorld.vue'
    import TodoItem from "./TodoItem";

    export default {
        name: 'Panel',
        components: {
            TodoItem,  // 注册依赖的组件
        },
        data() {
            return {
                msg: "Hello geektime",
                info: '',
                list: [ "Initial line" ],
            }
        },
        methods: {
            handleClick() {
                this.list.push(this.info);
                this.info = '';
            }
        },
        beforeCreate() {console.log("父组件beforeCreate");},
        created() {console.log("父组件Created");},
        beforeMount() {console.log("父组件beforeMount");},
        mounted() {console.log("父组件mounted");},
        beforeUpdate() {console.log("父组件beforeUpdate");},
        updated() {console.log("父组件updated")},
        beforeDestroy() {console.log("父组件beforeDestroy")},
        destroyed() {console.log("父组件destroyed")}
    }
</script>

<style>
    #app {
        font-family: Avenir, Helvetica, Arial, sans-serif;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        text-align: center;
        color: #2c3e50;
        margin-top: 60px;
    }
</style>

使用v-if="false"即可销毁里面的组件

  • App.vue
<template>
  <div id="app">
    <button v-on:click="destroyAll">清空组件</button>
    <div v-if="hasPanel">
      <Panel></Panel>
    </div>
  </div>
</template>

<script>
// import HelloWorld from './components/HelloWorld.vue'
import Panel from "./components/Panel";

export default {
  name: 'App',
  components: {
    Panel,  // 注册依赖的组件
  },
  data() {
    return {
      hasPanel: true
    }
  },
  methods: {
    destroyAll() {
      this.hasPanel = false;
    }
  },

}
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

image.png

销毁的时候,子组件销毁过程夹在父组件的beforeDestroy, Destroyed之间。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,198评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,663评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,985评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,673评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,994评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,399评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,717评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,407评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,112评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,371评论 2 241
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,891评论 1 256
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,255评论 2 250
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,881评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,010评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,764评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,412评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,299评论 2 260