VueJS 路由器 'Failed to mount component: template or render function not defined.'



我正在关注这个视频:https://laracasts.com/series/learn-vue-2-step-by-step/episodes/26?autoplay=true

我最初的问题在这里描述,但已经解决了。我把它包括在这里,以便你可以看到我到目前为止采取了哪些步骤。

现在,我收到此警告:[Vue 警告]:无法挂载组件:未定义模板或渲染函数。

警告还不错,但路由器视图没有显示。也就是说,"主页"和"关于"链接下方没有任何内容显示。

刀锋大师.php

<!doctype html>
<html lang="en">
<head>
<title>My App</title>
<link rel="stylesheet" href="/css/app.css">
</head>
<body>
<div id="app">
<router-link to="/">Home</router-link>
<router-link to="/about">About</router-link>
<router-view></router-view>
</div>
<script src="/js/app.js"></script>
</body>
</html>

首页

<template>
<div class="container">
<div class="row">
<div class="col-md-8 col-md-offset-2">
<div class="panel panel-default">
<div class="panel-heading">Home Page</div>
<div class="panel-body">
I'm an example component!
</div>
</div>
</div>
</div>
</div>
</template>
<script>
export default {
mounted() {
console.log('Component mounted.')
}
}
</script>

任何帮助将不胜感激。 谢谢!

[编辑1]

资源/资产/JS/应用程序.js

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

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

资源/资产/JS/引导程序.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');
}

[编辑2]

资源/资产/JS/路由.js

import VueRouter from 'vue-router';

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

啊!多亏了TheFallen的问题,我看到了我的问题。以下是我的路由.js文件应如下所示:

import VueRouter from 'vue-router';
import Home from './views/Home.vue';
let routes = [
{
path: '/',
component: Home
}
];
export default new VueRouter({
routes
});

相关内容

  • 没有找到相关文章

最新更新