我可以回答你的问题并举个例子。
基本上,将 Laravel 用作 React(或 JS)单页应用程序的 API 后端:
- 设置一个 Laravel 项目 - 它是后端,所以设置它和你想要的路由
1.a 建议 使您的 SPI URL 与您的 Laravel 应用程序本身可能用于页面请求或其他事情(例如“/ api/...")。
1.b Laravel(5+ 左右,我的例子是 5.1)附带一个名为“Elixir”的 Gulp/build 工具。它设置为在 resources/... 目录中查找脚本文件和视图等内容,因此我建议将您的脚本放在 resources/assets/scripts/app.js 之类的地方。
1.c(构建过程)假设您将 React 脚本放在 resources/assets/script 中,那么当您运行“gulp”并且运行 Elixir 任务以构建应用程序时,它会将将捆绑的 app.js 文件放入 public/js/app.js - Laravel 视图默认将 public/ 目录视为它们的根目录,因此您可以在索引页面中引用该构建文件作为“js/app.js”。
1.d 如果您对 Gulp 或 Elixir 不熟悉,我鼓励您阅读此页面以获得概述:
https://laravel.com/docs/5.1/elixir
- 设置 Laravel 的路由、您的索引页面和 API 内容。我建议路由“/”和所有非 API(或已知)路由来创建索引页面视图,我们将在其中加载 app.js ReactJS 应用程序文件。
2.a 值得注意的是,在我的示例中,目前我还没有实现 React 路由器,所以我暂时不考虑所有 React 路由。我假设这是您所知道的,因为您的问题似乎是“如何使后端成为 Laravel”。
Route::get('/', function () { return View::make('pages.index'); });
Route::group(['prefix' => 'api'], function () {
Route::get('tasks', 'TodosController@index');
});
2.b 设置路由以将请求映射到控制器操作,您可以在其中自定义响应。例如,您可以使用 JSON 响应 JSON API:
TodosController@index
$current_tasks = array(
array("id" => "00001", "task" => "Wake up", "complete" => true),
array("id" => "00002", "task" => "Eat breakfast with coffee power", "complete" => true),
array("id" => "00003", "task" => "Go to laptop", "complete" => true),
array("id" => "00004", "task" => "Finish React + Laravel Example app", "complete" => false),
array("id" => "00005", "task" => "Respond on StackOverflow", "complete" => false)
);
return response()->json($current_tasks);
- 就部署而言,您可能需要构建代码(我的示例就是这样做的)并将代码的构建 版本加载到您的生产索引页面或任何地方。您还将将其整体部署为 laravel 应用程序——您希望 Laravel 首先在外部看到路由,并希望 React 处理它自己的 URL 和路由。这样,假设您扩展了 SPA 但想要相同的后端,您只需将路由添加到您的 Laravel 应用程序作为路由文件中的异常/覆盖。
资源/页面/index.blade.php
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- The above 3 meta tags *must* come first in the head; any other head content must come *after* these tags -->
<title>BLaravel 5.1 + ReactJS Single-Page App</title>
<!-- Bootstrap -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" >
<link rel="stylesheet" href="css/app.css" />
<!-- BACKUP SCRIPT CNDS, for React -->
<!-- <script src="https://unpkg.com/react@15/dist/react.js"></script> -->
<!-- <script src="https://unpkg.com/react-dom@15/dist/react-dom.js"></script> -->
</head>
<body>
<!-- Container for React App -->
<div class="container" id="react-app-container"></div>
<!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script src="js/app.js"></script>
</body>
</html>
因为(据我所知)这种事情没有 Plnkr,所以我制作了 Laravel + React 的本地开发版本来说明我制作您似乎想要的那种应用程序的方法。它目前托管在我的 GitHub 帐户上,因此请随意克隆它并按照自述文件进行操作,如果有帮助,请使用它,或者请求编辑/帮助/澄清。
https://github.com/b-malone/Laravel5-ReactJS-Boilerplate.git
构建/设置命令(参考)
git clone ... [TEST/] && cd into [TEST/]
composer install
npm install
cp .env.example .env
gulp
php artisan serve
visit http://localhost:8000