-
-
Notifications
You must be signed in to change notification settings - Fork 6.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Co-authored-by: Hiroshi Ogawa <hi.ogawa.zz@gmail.com> Co-authored-by: Dario Piotrowicz <dario.piotrowicz@gmail.com> Co-authored-by: Vladimir Sheremet <sleuths.slews0s@icloud.com> Co-authored-by: Arnaud Barré <arnaud.barre@carbometrix.com> Co-authored-by: Anthony Fu <github@antfu.me> Co-authored-by: Dominik G <dominik.goepel@gmx.de> Co-authored-by: Igor Minar <i@igor.dev> Co-authored-by: Viktor Lázár <lazarv1982@gmail.com> Co-authored-by: Joaquín Sánchez <userquin@gmail.com> Co-authored-by: sapphi-red <49056869+sapphi-red@users.noreply.github.com> Co-authored-by: bluwy <bjornlu.dev@gmail.com>
- Loading branch information
1 parent
ccbfc1a
commit 242f550
Showing
165 changed files
with
8,602 additions
and
3,878 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
# HMR `hotUpdate` Plugin Hook | ||
|
||
::: tip Feedback | ||
Give us feedback at [Environment API feedback discussion](https://github.com/vitejs/vite/discussions/16358) | ||
::: | ||
|
||
We're planning to deprecate the `handleHotUpdate` plugin hook in favor of [`hotUpdate` hook](/guide/api-environment#the-hotupdate-hook) to be [Environment API](/guide/api-environment.md) aware, and handle additional watch events with `create` and `delete`. | ||
|
||
Affected scope: `Vite Plugin Authors` | ||
|
||
::: warning Future Deprecation | ||
`hotUpdate` was first introduced in `v6.0`. The deprecation of `handleHotUpdate` is planned for `v7.0`. We don't yet recommend moving away from `handleHotUpdate` yet. If you want to experiment and give us feedback, you can use the `future.removePluginHookHandleHotUpdate` to `"warn"` in your vite config. | ||
::: | ||
|
||
## Motivation | ||
|
||
The [`handleHotUpdate` hook](/guide/api-plugin.md#handlehotupdate) allows to perform custom HMR update handling. A list of modules to be updated is passed in the `HmrContext` | ||
|
||
```ts | ||
interface HmrContext { | ||
file: string | ||
timestamp: number | ||
modules: Array<ModuleNode> | ||
read: () => string | Promise<string> | ||
server: ViteDevServer | ||
} | ||
``` | ||
|
||
This hook is called once for all environments, and the passed modules have mixed information from the Client and SSR environments only. Once frameworks move to custom environments, a new hook that is called for each of them is needed. | ||
|
||
The new `hotUpdate` hook works in the same way as `handleHotUpdate` but it is called for each environment and receives a new `HotUpdateContext` instance: | ||
|
||
```ts | ||
interface HotUpdateContext { | ||
type: 'create' | 'update' | 'delete' | ||
file: string | ||
timestamp: number | ||
modules: Array<EnvironmentModuleNode> | ||
read: () => string | Promise<string> | ||
server: ViteDevServer | ||
} | ||
``` | ||
|
||
The current dev environment can be accessed like in other Plugin hooks with `this.environment`. The `modules` list will now be module nodes from the current environment only. Each environment update can define different update strategies. | ||
|
||
This hook is also now called for additional watch events and not only for `'update'`. Use `type` to differentiate between them. | ||
|
||
## Migration Guide | ||
|
||
Filter and narrow down the affected module list so that the HMR is more accurate. | ||
|
||
```js | ||
handleHotUpdate({ modules }) { | ||
return modules.filter(condition) | ||
} | ||
|
||
// Migrate to: | ||
|
||
hotUpdate({ modules }) { | ||
return modules.filter(condition) | ||
} | ||
``` | ||
|
||
Return an empty array and perform a full reload: | ||
|
||
```js | ||
handleHotUpdate({ server, modules, timestamp }) { | ||
// Invalidate modules manually | ||
const invalidatedModules = new Set() | ||
for (const mod of modules) { | ||
server.moduleGraph.invalidateModule( | ||
mod, | ||
invalidatedModules, | ||
timestamp, | ||
true | ||
) | ||
} | ||
server.ws.send({ type: 'full-reload' }) | ||
return [] | ||
} | ||
|
||
// Migrate to: | ||
|
||
hotUpdate({ modules, timestamp }) { | ||
// Invalidate modules manually | ||
const invalidatedModules = new Set() | ||
for (const mod of modules) { | ||
this.environment.moduleGraph.invalidateModule( | ||
mod, | ||
invalidatedModules, | ||
timestamp, | ||
true | ||
) | ||
} | ||
this.environment.hot.send({ type: 'full-reload' }) | ||
return [] | ||
} | ||
``` | ||
|
||
Return an empty array and perform complete custom HMR handling by sending custom events to the client: | ||
|
||
```js | ||
handleHotUpdate({ server }) { | ||
server.ws.send({ | ||
type: 'custom', | ||
event: 'special-update', | ||
data: {} | ||
}) | ||
return [] | ||
} | ||
|
||
// Migrate to... | ||
|
||
hotUpdate() { | ||
this.environment.hot.send({ | ||
type: 'custom', | ||
event: 'special-update', | ||
data: {} | ||
}) | ||
return [] | ||
} | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
# Breaking Changes | ||
|
||
List of breaking changes in Vite including API deprecations, removals, and changes. Most of the changes below can be opt-in using the [`future` option](/config/shared-options.html#future) in your Vite config. | ||
|
||
## Planned | ||
|
||
These changes are planned for the next major version of Vite. The deprecation or usage warnings will guide you where possible, and we're reaching out to framework, plugin authors, and users to apply these changes. | ||
|
||
- _No planned changes yet_ | ||
|
||
## Considering | ||
|
||
These changes are being considered and are often experimental APIs that intend to improve upon current usage patterns. As not all changes are listed here, please check out the [Experimental Label in Vite GitHub Discussions](https://github.com/vitejs/vite/discussions/categories/feedback?discussions_q=label%3Aexperimental+category%3AFeedback) for the full list. | ||
|
||
We don't recommend switching to these APIs yet. They are included in Vite to help us gather feedback. Please check these proposals and let us know how they work in your use case in each's linked GitHub Discussions. | ||
|
||
- [`this.environment` in Hooks](/changes/this-environment-in-hooks) | ||
- [HMR `hotUpdate` Plugin Hook](/changes/hotupdate-hook) | ||
- [Move to per-environment APIs](/changes/per-environment-apis) | ||
- [SSR using `ModuleRunner` API](/changes/ssr-using-modulerunner) | ||
- [Shared plugins during build](/changes/shared-plugins-during-build) | ||
|
||
## Past | ||
|
||
The changes below has been done or reverted. They are no longer relevant in the current major version. | ||
|
||
- _No past changes yet_ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
# Move to per-environment APIs | ||
|
||
::: tip Feedback | ||
Give us feedback at [Environment API feedback discussion](https://github.com/vitejs/vite/discussions/16358) | ||
::: | ||
|
||
Multiple APIs from ViteDevServer related to module graph has replaced with more isolated Environment APIs. | ||
|
||
- `server.moduleGraph` -> [`environment.moduleGraph`](/guide/api-environment#separate-module-graphs) | ||
- `server.transformRequest` -> `environment.transformRequest` | ||
- `server.warmupRequest` -> `environment.warmupRequest` | ||
|
||
Affect scope: `Vite Plugin Authors` | ||
|
||
::: warning Future Deprecation | ||
The Environment instance was first introduced at `v6.0`. The deprecation of `server.moduleGraph` and other methods that are now in environments is planned for `v7.0`. We don't recommend moving away from server methods yet. To identify your usage, set these in your vite config. | ||
|
||
```ts | ||
future: { | ||
removeServerModuleGraph: 'warn', | ||
removeServerTransformRequest: 'warn', | ||
} | ||
``` | ||
|
||
::: | ||
|
||
## Motivation | ||
|
||
// TODO: | ||
|
||
## Migration Guide | ||
|
||
// TODO: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
# Shared Plugins during Build | ||
|
||
::: tip Feedback | ||
Give us feedback at [Environment API feedback discussion](https://github.com/vitejs/vite/discussions/16358) | ||
::: | ||
|
||
// TODO: | ||
See [Shared plugins during build](/guide/api-environment.md#shared-plugins-during-build). | ||
|
||
Affect scope: `Vite Plugin Authors` | ||
|
||
::: warning Future Default Change | ||
`builder.sharedConfigBuild` was first introduce in `v6.0`. You can set it true to check how your plugins work with a shared config. We're looking for feedback about changing the default in a future major once the plugin ecosystem is ready. | ||
::: | ||
|
||
## Motivation | ||
|
||
// TODO: | ||
|
||
## Migration Guide | ||
|
||
// TODO: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# SSR using `ModuleRunner` API | ||
|
||
::: tip Feedback | ||
Give us feedback at [Environment API feedback discussion](https://github.com/vitejs/vite/discussions/16358) | ||
::: | ||
|
||
`server.ssrLoadModule` has been replaced by [Module Runner](/guide/api-environment#modulerunner). | ||
|
||
Affect scope: `Vite Plugin Authors` | ||
|
||
::: warning Future Deprecation | ||
`ModuleRunner` was first introduce in `v6.0`. The deprecation of `server.ssrLoadModule` is planned for a future major. To identify your usage, set `future.removeSrLoadModule` to `"warn"` in your vite config. | ||
::: | ||
|
||
## Motivation | ||
|
||
// TODO: | ||
|
||
## Migration Guide | ||
|
||
// TODO: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
# `this.environment` in Hooks | ||
|
||
::: tip Feedback | ||
Give us feedback at [Environment API feedback discussion](https://github.com/vitejs/vite/discussions/16358) | ||
::: | ||
|
||
Before Vite 6, only two environments were available: `client` and `ssr`. A single `options.ssr` plugin hook argument in `resolveId`, `load` and `transform` allowed plugin authors to differentiate between these two environments when processing modules in plugin hooks. In Vite 6, a Vite application can define any number of named environments as needed. We're introducing `this.environment` in the plugin context to interact with the environment of the current module in hooks. | ||
|
||
Affect scope: `Vite Plugin Authors` | ||
|
||
::: warning Future Deprecation | ||
`this.environment` was introduced in `v6.0`. The deprecation of `options.ssr` is planned for `v7.0`. At that point we'll start recommending migrating your plugins to use the new API. To identify your usage, set `future.removePluginHookSsrArgument` to `"warn"` in your vite config. | ||
::: | ||
|
||
## Motivation | ||
|
||
`this.environment` not only allow the plugin hook implementation to know the current environment name, it also gives access to the environment config options, module graph information, and transform pipeline (`environment.config`, `environment.moduleGraph`, `environment.transformRequest()`). Having the environment instance available in the context allows plugin authors to avoid the dependency of the whole dev server (typically cached at startup through the `configureServer` hook). | ||
|
||
## Migration Guide | ||
|
||
For the existing plugin to do a quick migration, replace the `options.ssr` argument with `this.environment.name !== 'client'` in the `resolveId`, `load` and `transform` hooks: | ||
|
||
```ts | ||
import { Plugin } from 'vite' | ||
|
||
export function myPlugin(): Plugin { | ||
return { | ||
name: 'my-plugin', | ||
resolveId(id, importer, options) { | ||
const isSSR = options.ssr // [!code --] | ||
const isSSR = this.environment.name !== 'client' // [!code ++] | ||
|
||
if (isSSR) { | ||
// SSR specific logic | ||
} else { | ||
// Client specific logic | ||
} | ||
}, | ||
} | ||
} | ||
``` | ||
|
||
For a more robust long term implementation, the plugin hook should handle for [multiple environments](/guide/api-environment.html#accessing-the-current-environment-in-hooks) using fine-grained environment options instead of relying on the environment name. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.