【发布时间】:2019-08-14 13:08:15
【问题描述】:
我是 Laravel 和 PHP 的新手,但熟悉 Vue 和 SPA。例如,我知道如何使用 Bcrypt 创建身份验证。但是,我使用 Laravel 运行 php artisan make:auth 并为后端创建了几个不同的端点。
我试图使用 Vue 将我的应用程序转换为 SPA,但是在 Vue 中使用路由会导致 web.php 中定义的路由出现问题。例如,我有这样的 web.php,有几个不同的路由。
<?php
Route::get('/{vue_capture?}', function () {
return view('app');
})->where('vue_capture', '^(?!storage).*$');
Route::get('/', function () {
return view('app');
});
Route::resource('Videos', 'VideoController')->middleware('auth','isAdmin');
Route::resource('Categories', 'CategoriesController')->middleware('auth');
Route::get('/search', 'VideoController@search')->middleware('auth');
Auth::routes();
Route::get('/settings/account', 'AccountsController@edit')->middleware('auth');
Route::get('/auth', 'AccountsController@get');
Route::put('/settings/account', 'AccountsController@update')->middleware('auth');
但是,我还有一个 routes.js 让 vue-router 使用以下内容处理路由:
import Home from './components/Home.vue'
import Videos from './components/Videos.vue'
import Categories from './components/Categories.vue'
export default{
mode: 'history',
routes: [
{
path:'/',
component:Home
},
{
path:'/Videos',
component:Videos
},
{
path:'/Categories',
component:Categories
},
{
path:'/login',
component:login
},
{
path:'/register',
component:register
},
{
path:'/logout',
component:logout
}
]
}
我知道如果您使用 SPA,Vue 应该接管路由,但是有什么方法可以同时使用这两者吗?我找不到任何可以解决这个问题的东西,但我不相信 Laravel 会让你选择使用他们的内置命令,比如 php artisan make:auth,或者如果你想要一个必须放弃所有这些并手动完成所有操作带有路由的 SPA。
我尝试过使用 Laravel 和/或 Vue 的不同 CRUD 教程。 我尝试将所有路由定向到 Vue 以让 vue-router 处理路由。 我尝试不将所有路由都提供给 vue-router 并保留我在 web.php 中拥有的后端路由
其他半相关的问题是我的路线甚至没有显示为使用 router-link 的链接。它只是显示为普通文本。但目前我的首要任务是路由问题。
【问题讨论】:
标签: laravel laravel-5 vue.js routes vue-router