Upgrading to Vite 3
Check the Migration Guide and the Changelog for more information.
Upgrading in Vite Ruby
Migrating to Vite 3
Follow Vite's Migration Guide and read the Changelog for more information.
For most Vite Ruby apps, you'll likely be able to upgrade without having to make any code changes.
You can upgrade by running bin/vite upgrade, which will bump vite_ruby
and any related dependencies to the latest version.
Latest Version
At the time of writing, the latest version is vite_ruby-3.2.0
, targeting the new Vite 3 release.
Version Numbers
From now on, versions of vite_ruby
will match Vite's major version number, for simplicity.
import.meta.glob
changes
In Vite 3, import.
will use keys relative to the current module.
// app/frontend/controllers/index.js
const controllers = import.meta.glob('../**/*_controller.js', { eager: true })
That code now transforms to:
const controllers = {
- '../controllers/home_controller.js': () => {}
+ './home_controller.js': () => {}
}
This can affect any usages that rely on the full path, such as when using stimulus-vite-helpers.
Depending on the the pattern you might not need to make any changes, but if you need the full path, you can leverage the new support for aliases:
const controllers = import.meta.glob('~/controllers/**/*_controller.js', { eager: true })
Prefer Aliases
An advantage of using aliases is that it's more explicit, works regardless of the file location, making it more robust when refactoring.