chore(deps): update dependency nuxt to v3
This PR contains the following updates:
| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
| nuxt (source) | ^2.14.12 -> ^3.0.0 |
Release Notes
nuxt/nuxt (nuxt)
v3.8.2
3.8.2 is a patch release focusing on bug fixes
👀 Highlights
3.8.2 is a patch release and we've deferred some exciting features in our next release (3.9.0, expected in December) but it does bring a significant Nitro minor release: v2.8.0. It's well worth checking out the release notes.
👉 Note that as Nitro has updated to rollup v4, but as Nuxt's vite dependency is still on rollup v3 until v3.9, you may experience type mismatches in modules or your projects if you are dependent on particular rollup plugins or plugin types.
✅ Upgrading
As usual, our recommendation for upgrading is to run:
nuxi upgrade --force
This will refresh your lockfile as well, and ensures that you pull in updates from other dependencies that Nuxt relies on, particularly in the unjs ecosystem.
👉 Changelog
🩹 Fixes
- vite: Skip warming up node builtins (#24162)
-
vite: Provide default values for
transformAssetUrls(#24173) -
nuxt: Wrap caught asyncData error in
createError(#24093) -
nuxt: Include plugin templates in
plugins.d.tsif they will be written (#23943) - nuxt: Handle multi-line slots in islands (#24212)
- nuxt: Fix replace regex used for slots in islands SSR (#24255)
-
vite: Use rollup replace plugin for
typeofoptimisations (#23903) -
nuxt: Provide route component names to
KeepAlivecache (#24024) -
schema: Use scule types for
runtimeConfigtype hints (#23696) -
nuxt: Deeply unwrap headers/query for
useFetchkey (#24307) - nuxt: Split component name case in each segment (#24318)
-
nuxt: Do not compute
useFetchkey from headers (#23462, #24333) - nuxt: Set framework info for nitro (#24340)
-
schema: Add type for
ignoreOptions(#24337) - nuxt: Log errors rendering islands (#24356)
-
nuxt: Respect custom timeout in
useFetch(#24364) -
nuxt: Use max length + iterations for
useCookietimeout (#24253) -
nuxt: Handle errors when booting app with
app:error(#24376)
📖 Documentation
- Remove unused import from example (#24168)
- Create a page explaining
import.meta(#24186) - Remove link to
.nuxtrcinnuxt/starter(56147b4a8) - Correct spelling from "opiniated" to "opinionated" (#24248)
- Mention new
defineNuxtPluginsyntax in bridge migration (#23036) - Mention
nuxt3-vuex-modulein migration guide (#24260) - Fix links to other auto-imports pages (#24269)
- Remove only (#24295)
- Update link to deno deploy provider docs (88ee7b7ea)
- Typos and wording tweaks for getting started section (#24319)
- Update
.gitignorein directory structure (#24338) - Add hint about
app.configplacement with customsrcDir(#24252) - Typos and wording tweaks for guide section (#24323)
- Remove path for
<ContentDoc>in example (#24244) - Mention changing directory in installation guide (#23680)
- Use
@nuxt/kit-nightlyin example (bdedc3207) - Update
nuxi-edgetonuxi-nightly(#24347) - Minor wording & formatting tweaks (#24349)
- Add AWS Amplify Hosting to hosting providers (#24371)
- Fix typo (#24375)
- Simplify to deployments page (13b93237e)
- Update to /deploy url (751dad7d7)
- Improve readme (07ab072bc)
🏡 Chore
- Extract
@nuxt/test-utilsto separate repo (#24146) - Remove stray router.options file (7fbcaf290)
- Fix
repositoryfields inpackage.json(54529c17d) - Add homepage and repo directory to
package.jsons (#24189) - Update to use
@nuxt/eslint-config(#24209) - Revert coverage provider version (b90b631df)
✅ Tests
❤️ Contributors
- Anthony Fu (@antfu)
- Sébastien Chopin (@Atinux)
- Christian Gil (@ChrisGV04)
- Clément Ollivier (@clemcode)
- Luke Nelson (@luc122c)
- Siegerts (@siegerts)
- Julien Huang (@huang-julien)
- Joe Hawes (@morehawes)
- Alexander Lichter (@manniL)
- Daniel Roe (@danielroe)
- Damian Głowala (@DamianGlowala)
- Pooya Parsa (@pi0)
- Boby Tiwari (@Boby900)
- Sita (@Pitabread8)
- Nils Wiesinger (@warflash)
- Webfansplz (@webfansplz)
- Aaron_Zhou (@Clarkkkk)
- 56 (@Nationalcat)
- Adrien Zaganelli (@adrienZ)
- Alonge Akintomide (@tomidealonge)
- Nasser BOUKEHIL (@nasrob)
- Passionate-bram (@passionate-bram)
- Maxime Pauvert (@maximepvrt)
- Dario Ferderber (@darioferderber)
- Brendan Mulholland (@bmulholland)
v3.8.1
3.8.1 is a patch release focused on bug fixes and performance improvements.
👉 Changelog
🔥 Performance
-
nuxt: Set
pageson nuxt app and deduplicate calls (#24032) - nuxt: Remove pure annotations plugin (#24033)
- nuxt: Use granular imports for auto-importing composables (#23951)
🩹 Fixes
- nuxt: Ensure we add prerender hints to correct event (#23799)
- nuxt: Close payload object (#23817)
-
schema: Accept single string for
extends(#23795) -
nuxt: Resolve internal
target: blanklinks with base (#23751) -
nuxt,schema: Use
std-envto detect whether app is being tested (#23830) -
nuxt: Use
.jsonextension for server components (#23802) - nuxt: Handle relative baseURL in nitro runtime config (#23841)
- nuxt: Improve watcher logs slightly (#23857)
-
nuxt: Resolve
@unhead/vuein template code (#23858) - kit: Resolve module tsconfig paths relative to dirs (#23860)
- nuxt,schema,vite,webpack: Analyze w/o overriding config (#23856)
-
nuxt: Don't use local fetch with an external
baseURL(#23884) - nuxt: Only skip refetching errors when hydrating (#23889)
-
webpack: Use lodash
cloneDeepagain (#23888) -
nuxt: Init
$fetchat entry start (#23906) - nuxt: Render a div when client-only hydrates w/o element (#23899)
-
vite: Remove
postcss-urland duplicatepostcss-import(#23861) - nuxt: Use route key for loading indicator/view transition (#23868)
-
nuxt: Unset
useCookievalue when it expires (#23549) -
vite: Use
h3cors handler for vite routes only (#23995) - schema: Correctly set default cssnano config (#23980)
- nuxt: Use payload url for isPrerendered, not current route (#24031)
- vite: Don't warm up css deps and normalise urls correctly (#23975)
-
kit: Fix
addServerImportsDirimplementation (#24000) - nuxt: Preserve hyphens in component/layout kebab names (#23902)
- nuxt: Do not register loading indicator hooks on server (#24052)
- nuxt: Reload nitro when spa loading template updates (#24036)
- nuxt: Resolve imports from virtual files (#24022)
- vite: Include more of warmup within try/catch (#24072)
-
nuxt: Use shared
isChangingPageutil in scrollBehavior (#24091) -
nuxt: Account for delay ≤ 0 in
useCookie(#24043) -
nuxt: Handle async children in
ClientFallback(#24086) -
vite: Normalise entry id for
typeCheckplugin (#24114)
💅 Refactors
-
nuxt: Use
useRequestEvent()internally (#23916)
📖 Documentation
- Add example of auto-importing components from npm package (#23792)
- Update minimum required Node version (#23821)
- getting-started: Add schema for server (6d0f45469)
- Fix typo in pnpm install command (#23851)
- Add missing comma (#23870)
- Add missing nitro hooks (#23865)
- Fix typo in layout description (#23862)
- Fix typo in runtime-config page (#23882)
- Fix typo (#23912)
- Fix typos (#23921)
- Rename 3.nuxt.config.md to 3.nuxt-config.md (#23819)
- composables: Avoid double read-more in useAppConfig (5fea17288)
- Skip View Transitions API route middleware on server (#23935)
- Clarify that bridge supports definePageMeta (#23944)
- Fix small typo in nuxt.config.ts documentation (#23961)
- Update link to composables doc (#23989)
- Add a more helpful comment (#23999)
- Fix
useFetchkey generation logic (#24082) - Fix typo (#24099)
- Fix imported
addPrerenderRoutesname (#24102) - Improve router docs on nuxt-injected options (#24126)
🏡 Chore
- Revert pnpm upgrade (e297368ee)
✅ Tests
-
nuxt: Test remote islands for
NuxtIsland(#23801) - Update basic fixture config for vite 5 (#23859)
- Await before asserting console logs (#24051)
🤖 CI
❤️ Contributors
- Fabian B (@madebyfabian)
- Mehdi Lahlou (@medfreeman)
- Webfansplz (@Webfansplz)
- Damian Głowala (@DamianGlowala)
- Andrey Yolkin (@AndreyYolkin)
- Vasilis Souvatzis (@vasisouv)
- Daniel Roe (@danielroe)
- Marco Solazzi (@dwightjack)
- NiJia Lin (@louis70109)
- Hugo Torzuoli (@HZooly)
- Mathieu ALBIN (@jaegar-wolf)
- Julien Huang (@huang-julien)
- Jaap Roes (@jaap3)
- Ryota Watanabe (@wattanx)
- Sébastien Chopin (@Atinux)
- Hossein-moghadam (@hosseinmoghaddam)
- Bastien Rossi (@bastienrossi)
- Ordago (@ordago)
- Jeffrey GONZALES (@jgonz3)
- Anthony Fu (@antfu)
- Leonard Mihalcea (@LeVoMihalcea)
- Paulo Pertierra (@paulo-pertierra)
- Conner (@connerblanton)
- KeJun (@KeJunMao)
- Bjorn Lu (@bluwy)
- Salman Khattak (@khattaksd)
- Luke Nelson (@luc122c)
- Jianqi Pan (@Jannchie)
- Matej Černý (@CernyMatej)
v3.8.0
👀 Highlights
We have a lot of exciting features in v3.8, and can't wait for you to try it out.
💻 Nuxi improvements
Just to remind you, we're now using the new Nuxt CLI which is now versioned separately. There are some exciting improvements there to follow, so do check out the latest releases. (For example, we now share the same port with the Vite websocket, meaning better support for docker containers in development.)
🚨 Built-in Nuxt DevTools
Nuxt DevTools v1.0.0 is out and we now think it's ready to be shipped as a direct dependency of Nuxt.
👉 You can check out the release notes for more information - and stay tuned for an article detailing our roadmap for the future.
📸 Nuxt Image auto-install
We've now made <NuxtImg> and <NuxtPicture> first-class built-in components, documenting them and auto-installing @nuxt/image the first time that they are used (#23717).
https://github.com/nuxt/nuxt/assets/28706372/597c9307-5741-4d9c-8eab-aad5bfef2ef2
We would definitely advise using @nuxt/image if you're using images in your site; it can apply optimisations to make your site more performant.
📂 Deeper layout scanning
🚨 This is a behaviour change so do take care with this one: 🚨
We now support scanning layouts within subfolders in ~/layouts in the same way as we do with ~/components.
File | Layout name -- | -- ~/layouts/desktop/default.vue | 'desktop-default' ~/layouts/desktop-base/base.vue | 'desktop-base' ~/layouts/desktop/index.vue | 'desktop'
See #20190 for more information
📊 App Manifest
We now support a built-in app manifest (see #21641), which generates a manifest at /_nuxt/builds/meta/<buildId>.json.
Initially this enables loading payloads only for prerendered routes, if a site is static (preventing 404s). It also enables client-side route rules. To begin with, only redirect route rules will have an effect; they will now redirect when performing client-side navigation. (More coming soon...!)
The app manifest also enables future enhancements including detection of outdated deployments by checking /_nuxt/builds/latest.json.
You can switch off this behaviour if you need to (but do let us know if you have any issues):
export default defineNuxtConfig({
experimental: {
appManifest: false
}
})
🤝 Scope and context improvements
We now define a 'scope' for Nuxt composables executed in plugins (#23667), which allows running synchronous cleanup before navigating away from your site, using the Vue onScopeDispose lifecycle method. This should fix an edge case with cookies (#23697) and also improves memory management, for example in Pinia stores (#23650). You can read more about Vue effect scopes.
We also now support native async context for the Vue composition API (#23526). In case you're unaware, we support native async context on Node and Bun, enabled with experimental.asyncContext. This can help address issues with missing a Nuxt instance. But it didn't previously affect missing Vue instances.
If you experience issues with 'Nuxt instance unavailable', enabling this option may solve your issues, and once we have cross-runtime support we are likely to enable it by default.
export default defineNuxtConfig({
experimental: {
asyncContext: true
}
})
🔗 NuxtLink defaults
We've supported defining your own NuxtLink components with the defineNuxtLink utility. We now support customising the options for the built-in <NuxtLink>, directly in your nuxt.config file (#23724). This can enable you to enforce trailing slash behaviour across your entire site, for example.
export default defineNuxtConfig({
experimental: {
defaults: {
nuxtLink: {
activeClass: 'nuxt-link-active',
trailingSlash: 'append'
}
}
}
})
⚡️ Data fetching improvements: deep and caching
We have two very significant new features for useAsyncData and useFetch:
- You can now set
deep: falseto prevent deep reactivity on thedataobject returned from these composables (#23600). It should be a performance improvement if you are returning large arrays or objects. The object will still update when refetched; it just won't trigger reactive effects if you change a property deep within thedata. - You can now use the
getCachedDataoption to handle custom caching for these composables (#20747)
const nuxtApp = useNuxtApp()
const { data } = await useAsyncData(() => { /* fetcher */ }, {
// this will not refetch if the key exists in the payload
getCachedData: key => nuxtApp.payload.static[key] ?? nuxtApp.payload.data[key]
})
We also support configuring some default values for these composables in an app-wide way (#23725):
export default defineNuxtConfig({
experimental: {
defaults: {
useAsyncData: {
deep: false
},
useFetch: {
retry: false,
retryDelay: 100,
retryStatusCodes: [500],
timeout: 100
}
}
}
})
🔢 Layer improvements
We now more carefully load layer plugins (#22889 and #23148) and middleware (#22925 and #23552) in the order of the layers, always loading your own plugins and middleware last. This should mean you can rely on utilities that layers may inject.
We've also added a test suite to cover these layer resolution changes.
And probably one of the most significant changes - if you are using remote layers we now clone these within your node_modules/ folder (#109) so layers can use dependencies with your project. See c12 release notes for full details.
😴 Nightly release channel
Every commit to the main branch of Nuxt is automatically deployed to a new release, for easier testing before releases. We've renamed this from the 'edge release channel' to the 'nightly release channel' to avoid confusion with edge deployments. And probably also with Microsoft Edge (though I haven't heard that anyone was confused with that one!)
➡️ nuxt3 is now nuxt-nightly
➡️ nuxi-edge is now nuxi-nightly
➡️ @nuxt/kit-edge is now @nuxt/kit-nightly
... and so on.
You can read more about how it works.
⚗️ Nitro v2.7
Nitro v2.7 has been released with lots of improvements and bug fixes - do check out the full changelog.
🔥 One of the most significant is that we now save ~40% of bundle size in production by using native fetch (which is supported in Node 18+) (#1724). So if possible, we'd recommend you update your Node version to at least 18.
💪 Type import changes
🚨 This is likely to need code changes in your project 🚨
Vue requires that type imports be explicit (so that the Vue compiler can correctly optimise and resolve type imports for props and so on). See core Vue tsconfig.json.
We've therefore taken the decision to turn on verbatimModuleSyntax by default in Nuxt projects, which will throw a type error if types are imported without an explicit type import. To resolve it you will need to update your imports:
- import { someFunction, SomeOptions } from 'some-library'
+ import { someFunction } from 'some-library'
+ import type { SomeOptions } from 'some-library'
You may also encounter modules in the Nuxt ecosystem that need to be updated; please open an issue for those modules. I'm also very happy to help if you're encountering any problems with this, if you're a module author. Just tag me and I'll take a look.
If for whatever reason you need to undo this change in your project you can set the following configuration:
export default defineNuxtConfig({
typescript: {
tsConfig: {
compilerOptions: {
verbatimModuleSyntax: false
}
}
}
})
However, we'd recommend only doing that temporarily, as Vue does need this option to be set for best results.
✅ Upgrading
As usual, our recommendation for upgrading is to run:
nuxi upgrade
👉 Changelog
🚀 Enhancements
-
kit: Add
addServerImportsandaddServerImportsDir(#23288) - nuxt: Warn when nesting nuxt links when SSR on dev (#23286)
-
nuxt: Add
prerenderRoutesssr composable (#22863) -
nuxt: Enable
appManifestby default (#23448) -
nuxt: Native async-context in vue's
withAsyncContext(#23526) - nuxt: Auto-install optional features on StackBlitz (#23607)
-
kit,nuxt,vite,webpack: Support
-nightlyextension (#23508) -
nuxt: Add
@nuxt/devtoolsas dependency and enable (#23576) -
nuxt: Support
deep: falsefor data composables (#23600) - nuxt: Custom cache support for data fetching composables (#20747)
- nuxt: Scan and register layouts in nested folders (#20190)
-
nuxt: Prompt to autoinstall
@nuxt/imagewhen it is used (#23717) -
nuxt: Allow configuring default
<NuxtLink>options (#23724) - nuxt: Allow customising defaults for data composables (#23725)
🔥 Performance
- vite: Don't print server compressed size after vite build (#23359)
- nuxt: Verbatim module syntax + restrict type discovery (#23447)
🩹 Fixes
-
nuxt: Initialise
asyncDataerrors withnull(#23428) - nuxt: Apply scoped styles to islands (#23386)
-
nuxt: Rename stub to avoid shadowing
vue-router(#23440) - nuxt: Stringify cookie values before broadcasting them (#23449)
-
kit: Don't force
config.autoImportinaddServerImports(#23472) -
nuxt: Ignore prefix if
clearNuxtStatecalled w/o keys (#23483) - nuxt: Decrement hydration count when rendering no route (#23476)
- nuxt: Compute fetch cache key with headers (#23462)
- nuxt: Mock hookable methods on nuxt 2 (#23502)
-
kit: Revert accidental change to
addPrerenderRoutesname (#23509) -
nuxt: Use
test/devas manifest buildId when appropriate (#23512) - nuxt: Don't print warnings for unresolved ids (#23604)
- nuxt: Use import alias when checking if plugin is wrapped (#23617)
-
nuxt: Tree shake all occurrences of
<DevOnly>(#23466) - nuxt: Give priority to later middleware when deduping (#23552)
- nuxt: Clear cookie BroadcastChannel when scope is disposed (#23664)
- nuxt: Provide global scope for nuxt plugin context (#23667)
-
nuxt: Resolve type error in options of
useFetch(#23693) -
webpack: Remove
lodash-es+ simplify postcss resolution (#23692) - nuxt: Skip hydration mismatches with client components (#19231)
- nuxt: Write cookie values before navigating away (#23697)
-
nuxt: Refetch both undefined/null values in
useAsyncData(#23351) - nuxt: Don't mark redirected routes as prerendered (#23707)
- nuxt: Respect custom export in component transform (#23715)
-
nuxt: Don't use
prerenderedAtto override app manifest (#23781) -
nuxt: Restore
prerenderedAtbehaviour pending next patch (108b1bdf7)
📖 Documentation
- Mention
listhenoptions on nuxi dev page (#23415) - Add examples for index.ts files on server routes (#23390)
- Improve data fetching section (#23420)
- Remove duplicated arrows (#23436)
- Extend description of
handlerforuseAsyncData(#23389) - Clarify bridge needs
nitroto useruntimeConfig(#23454) - Fix typo in README (#23500)
- Clarify that
bridge.typescriptoption must be set. (#23503) - Use html instead of xml for highlight (45c1e7f51)
- Fix component library example in docs (#23596)
- Typo in modules (#23602)
- Reword local module info (#23557)
- Add server concept (#23372)
- Improve
nuxt kitsection (#22375) - Update additional mentions to nightly release channel (c63f9a95d)
- Rename
/edge-channelpage to/nightly-release-channel(#23648) - Add section about computed url for data fetching (#23605)
- Fix typo (#23656)
- Remove extraneous brace (b9cb08cda)
- Fix other issues with
routeRulesexample (818dc626c) - Fix typo (#23716)
- Update types for useFetch/useAsyncData (#23730)
- Add info about
<NuxtImg>and<NuxtPicture>(#23741) - Update to new website (#23743)
- Remove redundant trailing slashes from links (#23744)
- Fix broken link (#23750)
🏡 Chore
- Fix various typos and update to US English (#23580)
- Add description field for packages (#23734)
- Bump nuxt devtools to 1.0 (#23752)
- Allow markdownlint upgrades (3d779fcf3)
- Remove huntr + encourage GitHub vulnerability reporting (#23754)
- Refresh lockfile (#23755)
- Update to nitropack 2.7.0 (#23780)
- Upgrade to c12 1.5 with configurable layers (#23782)
✅ Tests
🤖 CI
- Retry failing links 6 times (ad2a900fd)
- Only dedupe dependencies if they affect bundle size (#23736)
❤️ Contributors
- Daniel Roe (@danielroe)
- Pooya Parsa (@pi0)
- Anthony Fu (@antfu)
- Jianqi Pan (@Jannchie)
- Damian Głowala (@DamianGlowala)
- Sébastien Chopin (@Atinux)
- Alexander Lichter (@manniL)
- @boc-the-git
- Aleksandar Trpkovski (@Suv4o)
- Dario Ferderber (@darioferderber)
- Warflash (@warflash)
- Julien Huang (@huang-julien)
- Sacha Stafyniak (@stafyniaksacha)
- Alex Liu (@Mini-ghost)
- Orocane (@S1RANN)
- Italo (@DarkGhostHunter)
- @maritaria
- Andrey Yolkin (@Andrey Yolkin)
- Aaron_Zhou (@Clarkkkk)
- Estéban (@Barbapapazes)
- @sheriffderek
- Eugen Istoc (@genu)
- Mostafa Said (@i-Said-Code)
- Ezra Adeyinka (@adeyinkaezra123)
- Ryota Watanabe (@wattanx)
- Hendrik Heil (@hendrikheil)
- @0xflotus
- Albert Brand (@AlbertBrand)
- Arsen Goian (@arsengoian)
- Maxim (@MaxKostenko)
- Filip Weidemann (@filipweidemann)
- Toni Engelhardt (@toniengelhardt)
v3.7.4
3.7.4 is a regularly scheduled patch release.
✅ Upgrading
As usual, our recommendation for upgrading is to run:
nuxi upgrade
👉 Changelog
🩹 Fixes
- nuxt: Use original escapes/quotes in page re-exports (#23191)
- schema: Default devServer host to undefined (#23206)
- nuxt: Correct islandsTransform slot regex (#23226)
- nuxt: Handle vite preload-helper id with extension (#23230)
- nuxt: Load layer middlewares before project middlewares (#22925)
- nuxt: Don't incl overridden layer pages as nested children (#23238)
- vite: Explicitly set vite manifest path (#23276)
- nuxt: Experimental build manifest + client route rules (#21641)
- nuxt: Generate empty file when shim is disabled (#23333)
- nuxt: Apply right types to modules and their runtime files (#23240)
-
nuxt: Add import protection for
nuxt/*exports (#23357) - nuxt: Detect nested pages with /index segments (#23404)
- schema: Ignore pnpm store directory (3510cedc3)
💅 Refactors
- nuxt: Use built-in consola prompts (#23205)
-
kit,nuxt,schema: Use
consolaand improve test dx (#23302)
📖 Documentation
- Add documentation on
nuxt2command (#23211) - Clarify nuxi start command usage (#23215)
- Close
code-blockin migration guide (#23224) - Typo on
callHookmethod (#23231) - nuxt: Remove hanging word in modules docs (#23242)
- Update latest node.js version to 20.x (#23252)
- Add more files to
srcDirJSDoc (#23250) - Add steps for contributing to docs locally (#23270)
- Add support details and update roadmap (#21867, #21893)
- Add
nuxtApp.runWithContext(#23258) - Update 'scheduled' status name (#23307)
- Fix links to configuration options (#23324)
- Update link to
devtools.nuxt.com(#23350) - Add explicit
awaitto clarifysendRedirectis async (#23345) - Remove version from npm links to redirect to latest (#23371)
- Add
tryUseNuxtto kit context utils list (#23373)
🏡 Chore
🤖 CI
- Add lychee link checker (#23254)
- Rename
linkCheckerjob tolink-checker(#23319) - Don't run link checker on pushes to main (e0ddcfa9e)
❤️ Contributors
- Damian Głowala (@DamianGlowala)
- Tech Genius (@TechGenius7777)
- Daniel Roe (@danielroe)
- Percy Ma (@kecrily)
- Josh Deltener (@hecktarzuli)
- Arash (@arashsheyda)
- Abdul Al-Hasany (@abdul-alhasany)
- Muhammad Mahmoud (@MuhammadM1998)
- Pooya Parsa (@pi0)
- Alex Riviere (@fimion)
- Default-kaas (@default-kaas)
- Michel EDIGHOFFER (@edimitchel)
- Arkadiusz Sygulski (@Aareksio)
- Joaquín Sánchez (@userquin)
- Josh Jancourtz (@jcolpal)
- 翠 / Green (@sapphi-red)
- Jeremy Graziani (@AcelisWeaven)
- Julien Huang (@huang-julien)
- Andrey Yolkin (@AndreyYolkin)
- Petro Silenius (@PetroSilenius)
- Ryota Watanabe (@wattanx)
v3.7.3
3.7.3 is a hotfix release to address a regression introduced in 3.7.2.
👉 Changelog
🩹 Fixes
- nuxt: Ensure plugins retain original order (#23174)
-
nuxt: Allow importing server components from
#components(#23188)
💅 Refactors
- nuxt: Don't wrap server placeholders/client fallbacks (#21980)
📖 Documentation
- Added missing leading slash (#23169)
- Update internal issue decision making flowchart link (#23162)
❤️ Contributors
- Daniel Roe (@danielroe)
- Julien Huang (@huang-julien)
- Daniel Rivers (@DanielRivers)
- Tech Genius (@TechGenius7777)
v3.7.2
3.7.2 is a regularly scheduled patch release.
✅ Upgrading
As usual, our recommendation for upgrading is to run:
nuxi upgrade
👉 Changelog
🩹 Fixes
- nuxt: Scroll to top by default on dynamic routes (#22403)
-
nuxt: Don't
joinURLwith remote sources on NuxtIsland (#23093) -
nuxt: Exclude
data-vattrs from server component props (#23095) - nuxt: Handle optional params within a path segment (#23070)
-
nuxt: Include method when creating
useFetchauto key (#23086) -
vite: Add css to manifest without
cssCodeSplit(#23049) - nuxt: Find parent routes by exact path match (#23040)
-
nuxt: Load
spaLoadingTemplateif file exists (#23048) - nuxt: Handle unset spa-loading fallback (#23120)
-
kit: Improve generated
tsconfig.jsondefaults (#23121) - vite: Remove dev styles injected via absolute path (#23126)
-
nuxt: Default scanned layer components to priority
0(#23127) - nuxt: Allow granularly overriding pages in layers (#23134)
- nuxt: Respect layer order for other layer plugins (#23148)
- nuxt: Allow changing dirs within modules (#23133)
- nuxt: Allow overriding components + only warn if clash (#23156)
📖 Documentation
- Remove 'caching' section from data fetching (fe29948fe)
- Fix broken links on experimental features (#23052)
- Fix typo (#23060)
- Add
nameparam toPageMetainterface description (#23107) - Fix typo for
experimental.componentIslands(#23138) - Change NuxtLabs UI to Nuxt UI (#23150)
- Fix typo in
nuxi initcommand (#23155)
🏡 Chore
- nuxt: Update nuxi (#23145)
🤖 CI
- Test on node 20.5 rather than 20.6 (#23041)
- Update fixtures to node 18 (#23122)
- Unpin node 20 actions runners (#23135)
❤️ Contributors
- Daniel Roe (@danielroe)
- ML (@ijkml)
- Tech Genius (@TechGenius7777)
- Manthankumar Satani (@itsmnthn)
- David Gonzalez (@davidglezz)
- Maxime Pauvert (@maximepvrt)
- Dmitry Istomin (@tirojal)
- Maxim (@MaxKostenko)
- Julien Huang (@huang-julien)
- Sma11X (@Sma11X)
- Michel EDIGHOFFER (@edimitchel)
v3.7.1
3.7.1 is a regularly scheduled patch release.
✅ Upgrading
As usual, our recommendation for upgrading is to run:
nuxi upgrade --force
This will refresh your lockfile as well, and ensures that you pull in updates from other dependencies that Nuxt relies on, particularly in the unjs ecosystem.
👉 Changelog
🔥 Performance
🩹 Fixes
- nuxt: Exclude resolved vite virtual modules prefix (#22834)
- nuxt: Ensure typed layout prop persists through build (#22855)
-
nuxt: Render server components when
ssr: false(#22869) -
kit: Respect
prioritywhen registering components dirs (#22882) -
kit: Allow passing a string to
addLayout(#22902) -
nuxt: Ensure middleware is processed when returning
true(#22905) - nuxt: Unpause dom updates on error (#22945)
-
nuxt: Disallow
write: falsefor type templates (#22972) -
vite: Don't set explicit conditions in
shouldExternalize(#22991) - nuxt: Render inlined ssr styles before stylesheets (#22986)
- nuxt: Improve types within plugin templates (#22998)
- nuxt: Load layer plugins before project plugins (#22889)
-
nuxt: Use
destrin more places overJSON.parse(#22997) - nuxt: Resolve head instance from Nuxt app (#22973)
- nuxt: Always use increment for id with client side islands (#22975)
📖 Documentation
- Add info about dynamic nested routes (#22862)
- Update nuxt bridge migration guide (#22815)
- Rename nuxt-community to nuxt-modules (9991da634)
- Add banner for readme (e92d99db3)
- Simplify readme (681f92915)
- Text center on banner (ea5142176)
- Clarify that 'it' is
<NuxtPage>(#22912) - Update examples of dynamic
pageKey(#22920) - Fix types in 'server utilities' example (#22978)
- Describe
envobject for nuxt plugins (#22963) - Docs/3.api/3.utils/define-page-meta.md (#23006)
- Accessing custom props for
NuxtLayout(#22989) - Add information about server component context (#22964)
🏡 Chore
🤖 CI
- Create 2.x release branch as well (cdf9b5547)
- Use
GITHUB_REF_NAMEto get branch for release (d49ea58de) - Use changelogen utility to get current branch (7431e2258)
❤️ Contributors
- Julien Huang (@huang-julien)
- Saman (@bounoable)
- Harlan Wilton (@harlan-zw)
- Kekeocha Justin Chetachukwu (@justinkekeocha)
- Daniel Roe (@danielroe)
- Xjccc (@xjccc)
- Joaquín Sánchez (@userquin)
- Andrey Yolkin (AndreyYolkin)
- OrlS15 (@OrlS15)
- Alex Liu (@Mini-ghost)
- Jonas Thelemann (@dargmuesli)
- Sébastien Chopin (@Atinux)
- Ryota Watanabe (@wattanx)
- Heb (@Hebilicious)
- Maik Kowol (@94726)
v3.7.0
👀 Highlights
🐣 A New CLI
We've refactored nuxi using unjs/citty and this marks the first Nuxt release that depends on the new version, safely in its own repository. We have grand plans for this - check out some of the features + roadmap discussions in nuxt/cli and please feel free to contribute!
Nuxi is now decoupled from the main nuxt version - we plan to iterate and release nuxi more quickly in future so you can expect new things coming soon!
🕸️ Native Web Streams and Response
With improvements in unjs/h3 and unjs/nitro, it's now possible to directly return a Response object from server routes, meaning it's also possible to return and handle streams natively in Nuxt.
👉 Check out the full detail in the unjs/h3 and unjs/nitro release notes.
🔥 HTML Rendering Optimisations
This release comes with a couple of improvements in rendering HTML responses from the server. We now determine whether to preload/prefetch resources at build time (so you can customise this in the build:manifest hook). We also now manage rendering the HTML for them directly in unhead (#22179), which means you can configure the order for <link>, <meta>, <script>, <style>, and more. And - in our preliminary testing - it's even faster!
It's possible to opt-in to upcoming head improvements with the experimental.headNext flag. This currently includes a new ordering algorithm based on [capo.js](https://tog
Configuration
📅 Schedule: Branch creation - "every weekend" in timezone Europe/Berlin, Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
- [ ] If you want to rebase/retry this PR, check this box
This PR has been generated by Mend Renovate. View repository job log here.