0

0

laravel如何集成Inertia.js和React_Laravel集成Inertia.js与React教程

下次还敢

下次还敢

发布时间:2025-10-11 19:41:01

|

1141人浏览过

|

来源于php中文网

原创

集成 Inertia.js 可在 Laravel 中无缝使用 React 构建单页应用。1. 通过 Composer 安装 inertiajs/inertia-laravel 并运行 php artisan inertia:install 创建根模板;2. 确保 Inertia 中间件已注册;3. 使用 Vite 初始化 React 项目并安装 @inertiajs/react;4. 配置 vite.config.js 启用 React 插件并设置别名;5. 创建 resources/js/App.jsx 作为入口,调用 createInertiaApp 解析 Pages 目录下的组件;6. 更新 app.blade.php 添加挂载点并引入 @vite 指令;7. 在 resources/js/Pages/ 创建 Home.jsx 页面组件,利用 usePage 获取服务端传递的 props;8. 创建 HomeController,使用 Inertia::render('Home', [...]) 返回响应;9. 在 web.php 路由中绑定控制器方法;10. 同时启动 php artisan serve 和 npm run dev,访问页面即可获得无刷新的 SPA 体验。关键在于正确配置路径解析与别名,确保前端能加载页面组件。

laravel如何集成inertia.js和react_laravel集成inertia.js与react教程

想在 Laravel 项目中使用 React 并实现现代化的单页应用体验?集成 Inertia.js 是目前最简洁高效的方式。它让你无需构建独立的前端 API 服务,也能用 React 构建动态页面,同时保留 Laravel 的传统路由和控制器优势。

安装并配置 Inertia.js(Laravel 后端)

确保你有一个干净的 Laravel 项目。以下步骤将完成后端基础设置:

  • 通过 Composer 安装 Inertia Laravel 适配器
    composer require inertiajs/inertia-laravel
  • 发布 Inertia 的视图文件
    php artisan inertia:install
    这会创建 resources/views/app.blade.php 作为根模板。
  • 确保路由中间件已注册
    打开 app/Http/Kernel.php,确认 \Inertia\Middleware::class 已包含在 web 中间件组中。

设置前端环境(React + Vite 或 Webpack)

Inertia 支持主流构建工具。这里以更现代的 Vite 为例:

  • 初始化前端项目
    运行 npm init vite@latest,选择 React + JavaScript 模板,或直接使用以下命令:
    npm create vite@latest . -- --template react
  • 安装 Inertia 及相关依赖
    npm install @inertiajs/react @vitejs/plugin-react
  • 配置 vite.config.js
    修改 vite.config.js,启用 React 插件:
    import { defineConfig } from 'vite'
    import react from '@vitejs/plugin-react'
    

    export default defineConfig({ plugins: [react()], resolve: { alias: { '@': '/resources/js' } } })

创建根 React 布局与页面渲染

接下来设置前端入口文件,连接 Inertia 与 React。

Playground AI
Playground AI

AI图片生成和修图

下载
  • 创建主组件 App.jsx
    resources/js/App.jsx 中写入:
    import { createInertiaApp } from '@inertiajs/react'
    import { render } from 'react-dom'
    

    createInertiaApp({ resolve: name => require(./Pages/${name}), setup({ el, App, props }) { render(, el) }, })

  • 更新 Blade 模板加载 JS
    打开 resources/views/app.blade.php,确保有挂载点:
    
    
      
        Inertia App
      
      
        
    @vite('resources/js/App.jsx')

编写 React 页面并从 Laravel 路由返回

现在可以创建 React 页面并通过控制器返回。

  • 创建一个 React 页面组件
    resources/js/Pages/Home.jsx
    import { usePage } from '@inertiajs/react'
    

    export default function Home() { const { props } = usePage() return

    欢迎来到 {props.appName}

    }
  • 在 Laravel 控制器中返回 Inertia 响应
    使用 Artisan 创建控制器:
    php artisan make:controller HomeController
    编辑控制器方法:
    use Inertia\Inertia;
    

    public function index() { return Inertia::render('Home', [ 'appName' => config('app.name') ]); }

  • 定义路由
    routes/web.php 添加:
    use App\Http\Controllers\HomeController;
    Route::get('/', [HomeController::class, 'index']);
    

启动开发服务器:
php artisan servenpm run dev
访问 http://localhost:8000,你应该能看到 React 渲染的页面内容。

基本上就这些。Inertia.js 让 Laravel 和 React 协同工作变得非常自然。数据通过 props 传递,页面跳转由 Inertia 内部处理,无刷新体验即刻拥有。不复杂但容易忽略的是路径解析和别名配置,确保 resolve 函数能正确加载页面组件。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2691

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1663

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1525

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

954

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1420

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1509

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

3

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 8.6万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号