vue.js - Vue.extend()中,生命周期mounted好像一直不会触发

查看:260
本文介绍了vue.js - Vue.extend()中,生命周期mounted好像一直不会触发的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

Vue.component(), new Vue(), Vue.extend()有什么区别
Vue.extend()中,生命周期mounted好像一直不会触发,不知道怎么回事。created测试正常。

var test= Vue.extend({
                template: '#test',
                data: function() {
                    return {
                        msg: 'test'
                    }
                },
                mounted: function() {
                    console.log(1);
                }
            })

router.map({
                '/test': {
                    component: test
                }
            })

这时候component后面应该是new(实例化)的Vue而不能是Vue.extend()?

解决方案

Vue.component('my-component', { ... })

等同於

var myComponent = Vue.extend(...)
Vue.component('my-component', myComponent)

Vue.component 會註冊一個全局的組件,其會自動判斷第二個傳進來的是 Vue 繼承對象(Vue.extend) 還是 普通對象 ,如果是普通對象的話會自動在調用 Vue.extend ,所以你先繼承再傳還是直接傳普通對象對 Vue.component 的最終結果是沒差的。

而為何 mounted 沒有執行是因為 Vue.extend() 只是單純建立一個繼承 vue 構造 的對象,他並沒有實際掛載與渲染,自然 mounted 也不會執行,等你把它掛載並使用時,自然可以看到 mounted 被執行了。

<div id="app">
    <test></test>
</div>

var test= Vue.extend({
    template: '<div>123</div>',
    mounted: function() {
        console.log(1);
    }
})

new Vue({
    el: '#app',
    components: {
      test: test,
    },
})

这篇关于vue.js - Vue.extend()中,生命周期mounted好像一直不会触发的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆