Laravel Blade 热重载与 Vite

发布时间 作者

Laravel Blade Hot Refresh With Vite image

Laravel 团队更新了第一方 Laravel vite-plugin 包,以支持在 blade/任意文件更改时进行完整页面重载。当您编辑 blade 模板(或您配置的任何其他文件)时,Vite 将进行完整页面重载。在开发期间不再需要手动刷新浏览器!

当您安装新的 Laravel 项目时,您的 vite.config.js 文件中的基本配置如下所示

import { defineConfig } from 'vite';
import laravel from 'laravel-vite-plugin';
 
export default defineConfig({
plugins: [
laravel({
input: [
'resources/css/app.css',
'resources/js/app.js'
],
refresh: true,
}),
],
});

上面的代码片段是全新的 Laravel 应用程序随附的;您无需执行任何操作即可在新项目上启用热重载。

请注意 refresh 配置——当设置为 true 时,Laravel Vite 插件将在您更新以下路径中的文件时刷新页面

routes/**
resources/views/**

这种约定可能适合大多数项目,但是如果您想包含其他路径或文件,您可以配置 refresh 属性

import { defineConfig } from 'vite';
import laravel from 'laravel-vite-plugin';
 
export default defineConfig({
plugins: [
laravel({
input: [
'resources/css/app.css',
'resources/js/app.js'
],
refresh: [
'resources/routes/**',
'routes/**',
'resources/views/**',
],
}),
],
});

请参阅官方文档中的 使用 Blade 和路由,以获取有关配置选项的更多详细信息。

试一试

让我们设置一个演示 Laravel 应用程序来演示热重载。首先,让我们创建一个新的演示项目

laravel new blade-hot-reload --git
cd blade-hot-reload

安装项目后,将以下内容添加到 resources/views/ 中找到的 welcome.blade.php 文件的 <head/> 部分中的某个位置

@vite('resources/js/app.js')

接下来,您需要安装 NPM 依赖项并运行开发命令

npm install
npm run dev

就这样!如果您更改 blade 文件或路由,您将在控制台中看到类似以下内容

您所做的任何更改都应该立即反映出来,具体取决于您的本地开发环境设置。

Paul Redmond photo

Laravel 新闻的撰稿人。全栈 Web 开发人员和作者。

归档于
Cube

Laravel 新闻通讯

加入 40,000 多名其他开发人员,永不错过新的提示、教程等等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

没有妥协

来自 No Compromises 播客的两名经验丰富的开发人员 Joel 和 Aaron 现已提供,可为您的 Laravel 项目提供服务。 ⬧ 固定费率 $7500/月。 ⬧ 没有漫长的销售流程。 ⬧ 没有合同。 ⬧ 100% 退款保证。

没有妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,以确保您的 Web 应用程序取得成功。

Kirschbaum
Shift logo

Shift

运行旧版本的 Laravel?即时、自动的 Laravel 升级和代码现代化,以保持您的应用程序更新。

Shift
Bacancy logo

Bacancy

让您的项目充满活力,仅需 $2500/月即可聘请经验丰富的 Laravel 开发人员(4-6 年经验)。获得 160 小时的专业知识和 15 天免费试用。立即安排电话!

Bacancy
Lucky Media logo

Lucky Media

立即获得好运 - Laravel 开发的理想选择,拥有超过十年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 的电子商务。一个开源软件包,将现代无头电子商务功能的力量带到 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 职位平台

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动工具包

SaaSykit 是一个 Laravel SaaS 启动工具包,包含运行现代 SaaS 所需的所有功能。支付、精美结账、管理面板、用户仪表板、身份验证、即用型组件、统计信息、博客、文档等等。

SaaSykit:Laravel SaaS 启动工具包
Rector logo

Rector

您无缝升级 Laravel、降低成本并加速创新的合作伙伴,助力企业成功

Rector
MongoDB logo

MongoDB

通过将 MongoDB 和 Laravel 强力集成,增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解 MongoDB 灵活的现代数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在您的 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel Prompts 构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的站点搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包在您的 Laravel 应用程序中添加评论

阅读文章