Laravel - [Vue警告]:无法安装组件:未定义模板或渲染功能

问题描述 投票:1回答:1

所以我在Laravel创建了我的第一个SPA,以及vue。我决定使用Laravel混合而不是webpack,它似乎已经破坏了我,我现在收到了

[Vue warn]: Failed to mount component: template or render function not defined.

似乎发生在我添加<router-view></router-view>时。

我尝试过添加.default的“解决方案”,没有用。

export default new VueRouter({
    routes: [
        {
            path: '/',
            component: require('./views/Home.vue').default
        },
        {
            path: '/about',
            component: require('./views/About.vue').default
        }
    ]
});

app.js:

import './bootstrap';
import router from './routes';

new Vue({
    el: '#app',
    router,
});

bootstrap.js:

import Vue from 'vue';
import VueRouter from 'vue-router';
import axios from 'axios';


window.Vue = Vue;
Vue.use(VueRouter);

window.axios = axios;

window.axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest';

let token = document.head.querySelector('meta[name="csrf-token"]');

if (token) {
    window.axios.defaults.headers.common['X-CSRF-TOKEN'] = token.content;
} else {
    console.error('CSRF token not found: https://laravel.com/docs/csrf#csrf-x-csrf-token');
}

routes.js:

import VueRouter from 'vue-router';

export default new VueRouter({
    routes: [
        {
            path: '/',
            component: require('./views/Home.vue')
        }
    ]
});

HTML(welcome.blade.php):

<!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>Laravel</title>
        <link rel="stylesheet" href="/css/app.css" type="text/css">
    </head>
    <body>
        <div id="app">
            <router-link to="/">Home</router-link>

            <router-view></router-view>
        </div>
        <script src="/js/app.js"></script>
    </body>
</html>
javascript laravel vue.js laravel-mix
1个回答
0
投票

从bootstrap.js删除import VueRouter from 'vue-router';Vue.use(VueRouter);并将路由器插件添加到routes.js文件中的Vue并编辑如下:

import Vue from 'vue';
import VueRouter from 'vue-router';

Vue.use(VueRouter);
export default new VueRouter({
    routes: [
        {
            path: '/',
            component: require('./views/Home.vue')
        }
    ]
});

app.js是正确的。我已经实现并测试了这一切按预期工作。

© www.soinside.com 2019 - 2024. All rights reserved.