最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Vue 3 生命周期

    正文概述 掘金(爱嗯唧的豆妈)   2021-06-30   672

    在组件化的框架中,比如Vue为组件定义了生命周期这个概念。每个组件实例在被创建时都要经过一系列的初始化过程,比如模板编译、更新、销毁等。同时,在这些过程中也会运行一些叫做生命周期钩子的函数,他们提供给开发者在组件的不同阶段添加自己的代码逻辑的机会。

    使用过Vue2.x的朋友肯定对Vue2的生命周期钩子很熟悉,因为在实际开发中我们或多或少会用到过他们,比如mounted里的异步调用,比如beforeDestory的清除自定义事件等等。而在Vue3.0中,Vue2.x的Options API形式的生命周期钩子和新的Composition API都可以使用,来代码示例。

    Options API基本使用

    App.vue

    <template>
      <lifeCycles :msg="msg" v-if="flag" />
      <button @click="updateMsg">change message</button>
      <button @click="updateFlag">change flag</button>
    </template>
    
    <script>
    import LifeCycles from './components/LifeCycles.vue'
    
    export default {
      name: 'App',
      components: {
        LifeCycles
      },
      data() {
        return {
          msg: 'Welcome to Vue3',
          flag: true,
        }
      },
      methods: {
        updateMsg() {
          this.msg = 'Welcome to Vue3 Update ' + Date.now();
        },
        updateFlag() {
          this.flag = !this.flag;
        }
      }
    }
    </script>
    
    

    LifeCycles.vue

    <template>
        <p>生命周期 {{msg}}</p>
    </template>
    
    <script>
    export default {
        name: 'LifeCycles',
        props: {
            msg: String
        },
        beforeCreate() {
            console.log('before create')
        },
        created() {
            console.log('created')
        },
        beforeMount() {
            console.log('before mount')
        },
        mounted() {
            console.log('mounted')
        },
        beforeUpdate() {
            console.log('before update')
        },
        updated() {
            console.log('updated')
        },
        //beforeDestory已废弃
        beforeUnmount() {
            console.log('before unmount')
        },
        //destroyed已废弃
        unmounted() {
            console.log('mounted')
        }
    }
    </script>
    
    

    Vue 3 生命周期

    Composition API基本使用

    Compistion API的示例代码

    LifeCycles.vue

    <template>
        <p>生命周期 {{msg}}</p>
    </template>
    
    <script>
    import { onBeforeMount, onMounted, onBeforeUpdate, onUpdated, onBeforeUnmount, onUnmounted } from 'vue'
    
    export default {
        name: 'LifeCycles',
        props: {
            msg: String
        },
        //等同于 beforeCreate 和 created
        setup() {
            console.log('set up');
    
            onBeforeMount(() => {
                console.log('before mount')
            })
            onMounted(() => {
                console.log('mounted')
            })
            onBeforeUpdate(() => {
                console.log('before update')    
            })
            onUpdated(() => {
                console.log('updated')
            })
            onBeforeUnmount(() => {
                console.log('before unmount')
            })
            onUnmounted(() => {
                console.log('mounted')
            })
        },
    }
    </script>
    
    

    Vue 3 生命周期

    为什么会有Composition API?

    为了更好的代码组织

    假设一个vue组件是一个大型组件,它的内部有很多处理逻辑的关注点(对应Options API)。有没有一种碎片化的感觉,这种碎片化使得开发者很难去理解和维护组件。 Composition API的出现就是解决这个问题的,它将某个逻辑关注点相关的代码全都放在一个函数里,这样当需要修改一个功能时,就不需要在文件中跳来跳去。 Vue 3 生命周期

    示例对比

    这是一个用Vue2 Option API写的一个加法组件:

    • 3个参数,加数(num1)和被加数(num2),还有一个和(sum)
    • 2个input框
    • 1个method
    <template>
        <div class="add">
            <h3>Addition Calculator</h3>
            <form id="sum">
                <input type="text" class="form-control" v-model="num1">
                <input type="text" class="form-control" v-model="num2">
                <button @click="addNumbers" type="button" class="btn btn-light">
                    Add me!
                </button>
            </form>
            <p><strong>Sum:</strong> {{ sum }}</p>
        </div>
    </template>
    <script>
    export default {
        name: 'Add',
        data() {
            return {
                num1: 0,
                num2: 0,
                sum: 0
            };
        },
        methods: {
            addNumbers: function () {
                this.sum = parseInt(this.num1) + parseInt(this.num2);
            }
        }
    }
    </script>
    

    改成Composition API之后

    <template>
        <div class="add">
            <h3>Addition Calculator</h3>
            <form id="sumComp">
                <input type="text" class="form-control" v-model="num1">
                <input type="text" class="form-control" v-model="num2">
                <button @click="addNumbers" type="button" class="btn btn-light">
                Add me!
            </button>
            </form>
            <p><strong>Sum:</strong> {{ sum }}</p>
        </div>
    </template>
    <script>
    import { ref } from '@vue/composition-api';
    
    export default {
        name: 'AddComposition',
        setup() {
            let num1 = ref(0);
            let num2 = ref(0);
            let sum = ref(0);
            function addNumbers() {
                sum.value = parseInt(num1.value) + parseInt(num2.value);
            }
            return {
                num1,
                num2,
                sum,
                addNumbers
            }
        }
    }
    </script>
    

    为了更好的逻辑复用

    TODO

    如何选择?

    • 不建议共用,会引起混乱
    • 小型项目、业务逻辑简单,用Options API
    • 中大型项目、逻辑复杂,用Composition API

    起源地下载网 » Vue 3 生命周期

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元