[{"data":1,"prerenderedAt":2646},["ShallowReactive",2],{"navigation":3,"-blog-v3-16":1107,"-blog-v3-16-surround":2645},[4,1018],{"title":5,"titleTemplate":6,"icon":7,"path":8,"stem":9,"children":10,"page":108},"Docs",null,"i-lucide-bookmark","/docs","docs",[11,109,345,805,897,934,976],{"title":12,"titleTemplate":13,"icon":14,"path":15,"stem":16,"children":17,"page":108},"Get Started","%s · Get Started with Nuxt","i-lucide-rocket","/docs/getting-started","docs/1.getting-started",[18,23,28,33,38,43,48,53,58,63,68,73,78,83,88,93,98,103],{"title":19,"path":20,"stem":21,"titleTemplate":6,"icon":22},"Introduction","/docs/getting-started/introduction","docs/1.getting-started/01.introduction","i-lucide-info",{"title":24,"path":25,"stem":26,"titleTemplate":6,"icon":27},"Installation","/docs/getting-started/installation","docs/1.getting-started/02.installation","i-lucide-play",{"title":29,"path":30,"stem":31,"titleTemplate":6,"icon":32},"Configuration","/docs/getting-started/configuration","docs/1.getting-started/03.configuration","i-lucide-cog",{"title":34,"path":35,"stem":36,"titleTemplate":6,"icon":37},"Views","/docs/getting-started/views","docs/1.getting-started/04.views","i-lucide-panels-top-left",{"title":39,"path":40,"stem":41,"titleTemplate":6,"icon":42},"Assets","/docs/getting-started/assets","docs/1.getting-started/05.assets","i-lucide-image",{"title":44,"path":45,"stem":46,"titleTemplate":6,"icon":47},"Styling","/docs/getting-started/styling","docs/1.getting-started/06.styling","i-lucide-palette",{"title":49,"path":50,"stem":51,"titleTemplate":6,"icon":52},"Routing","/docs/getting-started/routing","docs/1.getting-started/07.routing","i-lucide-milestone",{"title":54,"path":55,"stem":56,"titleTemplate":6,"icon":57},"SEO and Meta","/docs/getting-started/seo-meta","docs/1.getting-started/08.seo-meta","i-lucide-file-search",{"title":59,"path":60,"stem":61,"titleTemplate":6,"icon":62},"Transitions","/docs/getting-started/transitions","docs/1.getting-started/09.transitions","i-lucide-toggle-right",{"title":64,"path":65,"stem":66,"titleTemplate":6,"icon":67},"Data Fetching","/docs/getting-started/data-fetching","docs/1.getting-started/10.data-fetching","i-lucide-cable",{"title":69,"path":70,"stem":71,"titleTemplate":6,"icon":72},"State Management","/docs/getting-started/state-management","docs/1.getting-started/11.state-management","i-lucide-database",{"title":74,"path":75,"stem":76,"titleTemplate":6,"icon":77},"Error Handling","/docs/getting-started/error-handling","docs/1.getting-started/12.error-handling","i-lucide-bug-off",{"title":79,"path":80,"stem":81,"titleTemplate":6,"icon":82},"Server","/docs/getting-started/server","docs/1.getting-started/13.server","i-lucide-pc-case",{"title":84,"path":85,"stem":86,"titleTemplate":6,"icon":87},"Layers","/docs/getting-started/layers","docs/1.getting-started/14.layers","i-lucide-layers",{"title":89,"path":90,"stem":91,"titleTemplate":6,"icon":92},"Prerendering","/docs/getting-started/prerendering","docs/1.getting-started/15.prerendering","i-lucide-file-code-2",{"title":94,"path":95,"stem":96,"titleTemplate":6,"icon":97},"Deployment","/docs/getting-started/deployment","docs/1.getting-started/16.deployment","i-lucide-cloud",{"title":99,"path":100,"stem":101,"titleTemplate":6,"icon":102},"Testing","/docs/getting-started/testing","docs/1.getting-started/17.testing","i-lucide-circle-check",{"title":104,"path":105,"stem":106,"titleTemplate":6,"icon":107},"Upgrade Guide","/docs/getting-started/upgrade","docs/1.getting-started/18.upgrade","i-lucide-circle-arrow-up",false,{"title":110,"titleTemplate":6,"icon":111,"path":112,"stem":113,"children":114,"page":108},"Guide","i-lucide-book-open","/docs/guide","docs/2.guide",[115,158,271,322],{"title":116,"titleTemplate":117,"icon":118,"path":119,"stem":120,"children":121,"page":108},"Key Concepts","%s · Nuxt Concepts","i-lucide-medal","/docs/guide/concepts","docs/2.guide/1.concepts",[122,126,130,134,138,142,146,150,154],{"title":123,"path":124,"stem":125,"titleTemplate":6},"Auto-imports","/docs/guide/concepts/auto-imports","docs/2.guide/1.concepts/1.auto-imports",{"title":127,"path":128,"stem":129,"titleTemplate":6},"Nuxt Lifecycle","/docs/guide/concepts/nuxt-lifecycle","docs/2.guide/1.concepts/10.nuxt-lifecycle",{"title":131,"path":132,"stem":133,"titleTemplate":6},"Vue.js Development","/docs/guide/concepts/vuejs-development","docs/2.guide/1.concepts/2.vuejs-development",{"title":135,"path":136,"stem":137,"titleTemplate":6},"Rendering Modes","/docs/guide/concepts/rendering","docs/2.guide/1.concepts/3.rendering",{"title":139,"path":140,"stem":141,"titleTemplate":6},"Server Engine","/docs/guide/concepts/server-engine","docs/2.guide/1.concepts/4.server-engine",{"title":143,"path":144,"stem":145,"titleTemplate":6},"Modules","/docs/guide/concepts/modules","docs/2.guide/1.concepts/5.modules",{"title":147,"path":148,"stem":149,"titleTemplate":6},"ES Modules","/docs/guide/concepts/esm","docs/2.guide/1.concepts/7.esm",{"title":151,"path":152,"stem":153,"titleTemplate":6},"TypeScript","/docs/guide/concepts/typescript","docs/2.guide/1.concepts/8.typescript",{"title":155,"path":156,"stem":157,"titleTemplate":6},"Code Style","/docs/guide/concepts/code-style","docs/2.guide/1.concepts/9.code-style",{"title":159,"titleTemplate":160,"icon":161,"path":162,"stem":163,"children":164,"page":108},"Directory Structure","%s · Nuxt Directory Structure","i-lucide-folders","/docs/guide/directory-structure","docs/2.guide/2.directory-structure",[165,170,174,178,182,186,190,194,198,202,206,210,214,218,222,226,230,235,239,243,247,251,255,259,263,267],{"title":166,"path":167,"stem":168,"titleTemplate":6,"icon":169},".nuxt","/docs/guide/directory-structure/nuxt","docs/2.guide/2.directory-structure/0.nuxt","i-lucide-folder",{"title":171,"path":172,"stem":173,"titleTemplate":6,"icon":169},".output","/docs/guide/directory-structure/output","docs/2.guide/2.directory-structure/0.output",{"title":175,"path":176,"stem":177,"titleTemplate":6,"icon":169},"assets","/docs/guide/directory-structure/assets","docs/2.guide/2.directory-structure/1.assets",{"title":179,"path":180,"stem":181,"titleTemplate":6,"icon":169},"components","/docs/guide/directory-structure/components","docs/2.guide/2.directory-structure/1.components",{"title":183,"path":184,"stem":185,"titleTemplate":6,"icon":169},"composables","/docs/guide/directory-structure/composables","docs/2.guide/2.directory-structure/1.composables",{"title":187,"path":188,"stem":189,"titleTemplate":6,"icon":169},"content","/docs/guide/directory-structure/content","docs/2.guide/2.directory-structure/1.content",{"title":191,"path":192,"stem":193,"titleTemplate":6,"icon":169},"layouts","/docs/guide/directory-structure/layouts","docs/2.guide/2.directory-structure/1.layouts",{"title":195,"path":196,"stem":197,"titleTemplate":6,"icon":169},"middleware","/docs/guide/directory-structure/middleware","docs/2.guide/2.directory-structure/1.middleware",{"title":199,"path":200,"stem":201,"titleTemplate":6,"icon":169},"modules","/docs/guide/directory-structure/modules","docs/2.guide/2.directory-structure/1.modules",{"title":203,"path":204,"stem":205,"titleTemplate":6,"icon":169},"node_modules","/docs/guide/directory-structure/node_modules","docs/2.guide/2.directory-structure/1.node_modules",{"title":207,"path":208,"stem":209,"titleTemplate":6,"icon":169},"pages","/docs/guide/directory-structure/pages","docs/2.guide/2.directory-structure/1.pages",{"title":211,"path":212,"stem":213,"titleTemplate":6,"icon":169},"plugins","/docs/guide/directory-structure/plugins","docs/2.guide/2.directory-structure/1.plugins",{"title":215,"path":216,"stem":217,"titleTemplate":6,"icon":169},"public","/docs/guide/directory-structure/public","docs/2.guide/2.directory-structure/1.public",{"title":219,"path":220,"stem":221,"titleTemplate":6,"icon":169},"server","/docs/guide/directory-structure/server","docs/2.guide/2.directory-structure/1.server",{"title":223,"path":224,"stem":225,"titleTemplate":6,"icon":169},"shared","/docs/guide/directory-structure/shared","docs/2.guide/2.directory-structure/1.shared",{"title":227,"path":228,"stem":229,"titleTemplate":6,"icon":169},"utils","/docs/guide/directory-structure/utils","docs/2.guide/2.directory-structure/1.utils",{"title":231,"path":232,"stem":233,"titleTemplate":6,"icon":234},".env","/docs/guide/directory-structure/env","docs/2.guide/2.directory-structure/2.env","i-lucide-file",{"title":236,"path":237,"stem":238,"titleTemplate":6,"icon":234},".gitignore","/docs/guide/directory-structure/gitignore","docs/2.guide/2.directory-structure/2.gitignore",{"title":240,"path":241,"stem":242,"titleTemplate":6,"icon":234},".nuxtignore","/docs/guide/directory-structure/nuxtignore","docs/2.guide/2.directory-structure/2.nuxtignore",{"title":244,"path":245,"stem":246,"titleTemplate":6,"icon":234},".nuxtrc","/docs/guide/directory-structure/nuxtrc","docs/2.guide/2.directory-structure/2.nuxtrc",{"title":248,"path":249,"stem":250,"titleTemplate":6,"icon":234},"app.vue","/docs/guide/directory-structure/app","docs/2.guide/2.directory-structure/3.app",{"title":252,"path":253,"stem":254,"titleTemplate":6,"icon":234},"app.config.ts","/docs/guide/directory-structure/app-config","docs/2.guide/2.directory-structure/3.app-config",{"title":256,"path":257,"stem":258,"titleTemplate":6,"icon":234},"error.vue","/docs/guide/directory-structure/error","docs/2.guide/2.directory-structure/3.error",{"title":260,"path":261,"stem":262,"titleTemplate":6,"icon":234},"nuxt.config.ts","/docs/guide/directory-structure/nuxt-config","docs/2.guide/2.directory-structure/3.nuxt-config",{"title":264,"path":265,"stem":266,"titleTemplate":6,"icon":234},"package.json","/docs/guide/directory-structure/package","docs/2.guide/2.directory-structure/3.package",{"title":268,"path":269,"stem":270,"titleTemplate":6,"icon":234},"tsconfig.json","/docs/guide/directory-structure/tsconfig","docs/2.guide/2.directory-structure/3.tsconfig",{"title":272,"titleTemplate":273,"icon":274,"path":275,"stem":276,"children":277,"page":108},"Going Further","%s · Nuxt Advanced","i-lucide-star","/docs/guide/going-further","docs/2.guide/3.going-further",[278,282,286,290,294,298,302,306,310,314,318],{"title":279,"path":280,"stem":281,"titleTemplate":6},"Experimental Features","/docs/guide/going-further/experimental-features","docs/2.guide/3.going-further/1.experimental-features",{"title":283,"path":284,"stem":285,"titleTemplate":6},"Features","/docs/guide/going-further/features","docs/2.guide/3.going-further/1.features",{"title":287,"path":288,"stem":289,"titleTemplate":6},"How Nuxt Works?","/docs/guide/going-further/internals","docs/2.guide/3.going-further/1.internals",{"title":291,"path":292,"stem":293,"titleTemplate":6},"Runtime Config","/docs/guide/going-further/runtime-config","docs/2.guide/3.going-further/10.runtime-config",{"title":295,"path":296,"stem":297,"titleTemplate":6},"Nightly Release Channel","/docs/guide/going-further/nightly-release-channel","docs/2.guide/3.going-further/11.nightly-release-channel",{"title":299,"path":300,"stem":301,"titleTemplate":6},"Lifecycle Hooks","/docs/guide/going-further/hooks","docs/2.guide/3.going-further/2.hooks",{"title":303,"path":304,"stem":305,"titleTemplate":6},"Module Author Guide","/docs/guide/going-further/modules","docs/2.guide/3.going-further/3.modules",{"title":307,"path":308,"stem":309,"titleTemplate":6},"Nuxt Kit","/docs/guide/going-further/kit","docs/2.guide/3.going-further/4.kit",{"title":311,"path":312,"stem":313,"titleTemplate":6},"NuxtApp","/docs/guide/going-further/nuxt-app","docs/2.guide/3.going-further/6.nuxt-app",{"title":315,"path":316,"stem":317,"titleTemplate":6},"Authoring Nuxt Layers","/docs/guide/going-further/layers","docs/2.guide/3.going-further/7.layers",{"title":319,"path":320,"stem":321,"titleTemplate":6},"Debugging","/docs/guide/going-further/debugging","docs/2.guide/3.going-further/9.debugging",{"title":323,"titleTemplate":324,"icon":325,"path":326,"stem":327,"children":328,"page":108},"Recipes","%s · Recipes","i-lucide-cooking-pot","/docs/guide/recipes","docs/2.guide/4.recipes",[329,333,337,341],{"title":330,"path":331,"stem":332,"titleTemplate":6},"Custom Routing","/docs/guide/recipes/custom-routing","docs/2.guide/4.recipes/1.custom-routing",{"title":334,"path":335,"stem":336,"titleTemplate":6},"Vite Plugins","/docs/guide/recipes/vite-plugin","docs/2.guide/4.recipes/2.vite-plugin",{"title":338,"path":339,"stem":340,"titleTemplate":6},"Custom useFetch","/docs/guide/recipes/custom-usefetch","docs/2.guide/4.recipes/3.custom-usefetch",{"title":342,"path":343,"stem":344,"titleTemplate":6},"Sessions and Authentication","/docs/guide/recipes/sessions-and-authentication","docs/2.guide/4.recipes/4.sessions-and-authentication",{"title":346,"titleTemplate":347,"icon":348,"path":349,"stem":350,"children":351,"page":108},"API","%s · Nuxt API","i-lucide-code-xml","/docs/api","docs/3.api",[352,416,539,654,721,787,800],{"title":353,"titleTemplate":354,"icon":355,"path":356,"stem":357,"children":358,"page":108},"Components","%s · Nuxt Components","i-lucide-box","/docs/api/components","docs/3.api/1.components",[359,363,367,371,375,379,384,388,392,396,400,404,408,412],{"title":360,"path":361,"stem":362,"titleTemplate":6},"\u003CClientOnly>","/docs/api/components/client-only","docs/3.api/1.components/1.client-only",{"title":364,"path":365,"stem":366,"titleTemplate":6},"\u003CDevOnly>","/docs/api/components/dev-only","docs/3.api/1.components/1.dev-only",{"title":368,"path":369,"stem":370,"titleTemplate":6},"\u003CNuxtClientFallback>","/docs/api/components/nuxt-client-fallback","docs/3.api/1.components/1.nuxt-client-fallback",{"title":372,"path":373,"stem":374,"titleTemplate":6},"\u003CNuxtPicture>","/docs/api/components/nuxt-picture","docs/3.api/1.components/10.nuxt-picture",{"title":376,"path":377,"stem":378,"titleTemplate":6},"\u003CTeleport>","/docs/api/components/teleports","docs/3.api/1.components/11.teleports",{"title":380,"path":381,"stem":382,"titleTemplate":6,"badge":383},"\u003CNuxtRouteAnnouncer>","/docs/api/components/nuxt-route-announcer","docs/3.api/1.components/12.nuxt-route-announcer","New",{"title":385,"path":386,"stem":387,"titleTemplate":6},"\u003CNuxtPage>","/docs/api/components/nuxt-page","docs/3.api/1.components/2.nuxt-page",{"title":389,"path":390,"stem":391,"titleTemplate":6},"\u003CNuxtLayout>","/docs/api/components/nuxt-layout","docs/3.api/1.components/3.nuxt-layout",{"title":393,"path":394,"stem":395,"titleTemplate":6},"\u003CNuxtLink>","/docs/api/components/nuxt-link","docs/3.api/1.components/4.nuxt-link",{"title":397,"path":398,"stem":399,"titleTemplate":6},"\u003CNuxtLoadingIndicator>","/docs/api/components/nuxt-loading-indicator","docs/3.api/1.components/5.nuxt-loading-indicator",{"title":401,"path":402,"stem":403,"titleTemplate":6},"\u003CNuxtErrorBoundary>","/docs/api/components/nuxt-error-boundary","docs/3.api/1.components/6.nuxt-error-boundary",{"title":405,"path":406,"stem":407,"titleTemplate":6},"\u003CNuxtWelcome>","/docs/api/components/nuxt-welcome","docs/3.api/1.components/7.nuxt-welcome",{"title":409,"path":410,"stem":411,"titleTemplate":6},"\u003CNuxtIsland>","/docs/api/components/nuxt-island","docs/3.api/1.components/8.nuxt-island",{"title":413,"path":414,"stem":415,"titleTemplate":6},"\u003CNuxtImg>","/docs/api/components/nuxt-img","docs/3.api/1.components/9.nuxt-img",{"title":417,"titleTemplate":418,"icon":419,"path":420,"stem":421,"children":422,"page":108},"Composables","%s · Nuxt Composables","i-lucide-arrow-left-right","/docs/api/composables","docs/3.api/2.composables",[423,427,431,435,439,443,447,451,455,459,463,467,471,475,479,483,487,491,495,499,503,507,511,515,519,523,527,531,535],{"title":424,"path":425,"stem":426,"titleTemplate":6},"onPrehydrate","/docs/api/composables/on-prehydrate","docs/3.api/2.composables/on-prehydrate",{"title":428,"path":429,"stem":430,"titleTemplate":6},"useAppConfig","/docs/api/composables/use-app-config","docs/3.api/2.composables/use-app-config",{"title":432,"path":433,"stem":434,"titleTemplate":6},"useAsyncData","/docs/api/composables/use-async-data","docs/3.api/2.composables/use-async-data",{"title":436,"path":437,"stem":438,"titleTemplate":6},"useCookie","/docs/api/composables/use-cookie","docs/3.api/2.composables/use-cookie",{"title":440,"path":441,"stem":442,"titleTemplate":6},"useError","/docs/api/composables/use-error","docs/3.api/2.composables/use-error",{"title":444,"path":445,"stem":446,"titleTemplate":6},"useFetch","/docs/api/composables/use-fetch","docs/3.api/2.composables/use-fetch",{"title":448,"path":449,"stem":450,"titleTemplate":6},"useHead","/docs/api/composables/use-head","docs/3.api/2.composables/use-head",{"title":452,"path":453,"stem":454,"titleTemplate":6},"useHeadSafe","/docs/api/composables/use-head-safe","docs/3.api/2.composables/use-head-safe",{"title":456,"path":457,"stem":458,"titleTemplate":6},"useHydration","/docs/api/composables/use-hydration","docs/3.api/2.composables/use-hydration",{"title":460,"path":461,"stem":462,"titleTemplate":6},"useLazyAsyncData","/docs/api/composables/use-lazy-async-data","docs/3.api/2.composables/use-lazy-async-data",{"title":464,"path":465,"stem":466,"titleTemplate":6},"useLazyFetch","/docs/api/composables/use-lazy-fetch","docs/3.api/2.composables/use-lazy-fetch",{"title":468,"path":469,"stem":470,"titleTemplate":6},"useLoadingIndicator","/docs/api/composables/use-loading-indicator","docs/3.api/2.composables/use-loading-indicator",{"title":472,"path":473,"stem":474,"titleTemplate":6},"useNuxtApp","/docs/api/composables/use-nuxt-app","docs/3.api/2.composables/use-nuxt-app",{"title":476,"path":477,"stem":478,"titleTemplate":6},"useNuxtData","/docs/api/composables/use-nuxt-data","docs/3.api/2.composables/use-nuxt-data",{"title":480,"path":481,"stem":482,"titleTemplate":6},"usePreviewMode","/docs/api/composables/use-preview-mode","docs/3.api/2.composables/use-preview-mode",{"title":484,"path":485,"stem":486,"titleTemplate":6},"useRequestEvent","/docs/api/composables/use-request-event","docs/3.api/2.composables/use-request-event",{"title":488,"path":489,"stem":490,"titleTemplate":6},"useRequestFetch","/docs/api/composables/use-request-fetch","docs/3.api/2.composables/use-request-fetch",{"title":492,"path":493,"stem":494,"titleTemplate":6},"useRequestHeader","/docs/api/composables/use-request-header","docs/3.api/2.composables/use-request-header",{"title":496,"path":497,"stem":498,"titleTemplate":6},"useRequestHeaders","/docs/api/composables/use-request-headers","docs/3.api/2.composables/use-request-headers",{"title":500,"path":501,"stem":502,"titleTemplate":6},"useRequestURL","/docs/api/composables/use-request-url","docs/3.api/2.composables/use-request-url",{"title":504,"path":505,"stem":506,"titleTemplate":6},"useResponseHeader","/docs/api/composables/use-response-header","docs/3.api/2.composables/use-response-header",{"title":508,"path":509,"stem":510,"titleTemplate":6},"useRoute","/docs/api/composables/use-route","docs/3.api/2.composables/use-route",{"title":512,"path":513,"stem":514,"titleTemplate":6,"badge":383},"useRouteAnnouncer","/docs/api/composables/use-route-announcer","docs/3.api/2.composables/use-route-announcer",{"title":516,"path":517,"stem":518,"titleTemplate":6},"useRouter","/docs/api/composables/use-router","docs/3.api/2.composables/use-router",{"title":520,"path":521,"stem":522,"titleTemplate":6},"useRuntimeConfig","/docs/api/composables/use-runtime-config","docs/3.api/2.composables/use-runtime-config",{"title":524,"path":525,"stem":526,"titleTemplate":6},"useRuntimeHook","/docs/api/composables/use-runtime-hook","docs/3.api/2.composables/use-runtime-hook",{"title":528,"path":529,"stem":530,"titleTemplate":6},"useSeoMeta","/docs/api/composables/use-seo-meta","docs/3.api/2.composables/use-seo-meta",{"title":532,"path":533,"stem":534,"titleTemplate":6},"useServerSeoMeta","/docs/api/composables/use-server-seo-meta","docs/3.api/2.composables/use-server-seo-meta",{"title":536,"path":537,"stem":538,"titleTemplate":6},"useState","/docs/api/composables/use-state","docs/3.api/2.composables/use-state",{"title":540,"titleTemplate":541,"icon":542,"path":543,"stem":544,"children":545,"page":108},"Utils","%s · Nuxt Utils","i-lucide-square-function","/docs/api/utils","docs/3.api/3.utils",[546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618,622,626,630,634,638,642,646,650],{"title":547,"path":548,"stem":549,"titleTemplate":6},"$fetch","/docs/api/utils/dollarfetch","docs/3.api/3.utils/$fetch",{"title":551,"path":552,"stem":553,"titleTemplate":6},"abortNavigation","/docs/api/utils/abort-navigation","docs/3.api/3.utils/abort-navigation",{"title":555,"path":556,"stem":557,"titleTemplate":6},"addRouteMiddleware","/docs/api/utils/add-route-middleware","docs/3.api/3.utils/add-route-middleware",{"title":559,"path":560,"stem":561,"titleTemplate":6,"badge":383},"callOnce","/docs/api/utils/call-once","docs/3.api/3.utils/call-once",{"title":563,"path":564,"stem":565,"titleTemplate":6},"clearError","/docs/api/utils/clear-error","docs/3.api/3.utils/clear-error",{"title":567,"path":568,"stem":569,"titleTemplate":6},"clearNuxtData","/docs/api/utils/clear-nuxt-data","docs/3.api/3.utils/clear-nuxt-data",{"title":571,"path":572,"stem":573,"titleTemplate":6},"clearNuxtState","/docs/api/utils/clear-nuxt-state","docs/3.api/3.utils/clear-nuxt-state",{"title":575,"path":576,"stem":577,"titleTemplate":6},"createError","/docs/api/utils/create-error","docs/3.api/3.utils/create-error",{"title":579,"path":580,"stem":581,"titleTemplate":6},"defineNuxtComponent","/docs/api/utils/define-nuxt-component","docs/3.api/3.utils/define-nuxt-component",{"title":583,"path":584,"stem":585,"titleTemplate":6},"defineNuxtRouteMiddleware","/docs/api/utils/define-nuxt-route-middleware","docs/3.api/3.utils/define-nuxt-route-middleware",{"title":587,"path":588,"stem":589,"titleTemplate":6},"definePageMeta","/docs/api/utils/define-page-meta","docs/3.api/3.utils/define-page-meta",{"title":591,"path":592,"stem":593,"titleTemplate":6},"defineRouteRules","/docs/api/utils/define-route-rules","docs/3.api/3.utils/define-route-rules",{"title":595,"path":596,"stem":597,"titleTemplate":6},"navigateTo","/docs/api/utils/navigate-to","docs/3.api/3.utils/navigate-to",{"title":599,"path":600,"stem":601,"titleTemplate":6},"onBeforeRouteLeave","/docs/api/utils/on-before-route-leave","docs/3.api/3.utils/on-before-route-leave",{"title":603,"path":604,"stem":605,"titleTemplate":6},"onBeforeRouteUpdate","/docs/api/utils/on-before-route-update","docs/3.api/3.utils/on-before-route-update",{"title":607,"path":608,"stem":609,"titleTemplate":6},"onNuxtReady","/docs/api/utils/on-nuxt-ready","docs/3.api/3.utils/on-nuxt-ready",{"title":611,"path":612,"stem":613,"titleTemplate":6},"prefetchComponents","/docs/api/utils/prefetch-components","docs/3.api/3.utils/prefetch-components",{"title":615,"path":616,"stem":617,"titleTemplate":6},"preloadComponents","/docs/api/utils/preload-components","docs/3.api/3.utils/preload-components",{"title":619,"path":620,"stem":621,"titleTemplate":6},"preloadRouteComponents","/docs/api/utils/preload-route-components","docs/3.api/3.utils/preload-route-components",{"title":623,"path":624,"stem":625,"titleTemplate":6},"prerenderRoutes","/docs/api/utils/prerender-routes","docs/3.api/3.utils/prerender-routes",{"title":627,"path":628,"stem":629,"titleTemplate":6,"badge":383},"refreshCookie","/docs/api/utils/refresh-cookie","docs/3.api/3.utils/refresh-cookie",{"title":631,"path":632,"stem":633,"titleTemplate":6},"refreshNuxtData","/docs/api/utils/refresh-nuxt-data","docs/3.api/3.utils/refresh-nuxt-data",{"title":635,"path":636,"stem":637,"titleTemplate":6},"reloadNuxtApp","/docs/api/utils/reload-nuxt-app","docs/3.api/3.utils/reload-nuxt-app",{"title":639,"path":640,"stem":641,"titleTemplate":6},"setPageLayout","/docs/api/utils/set-page-layout","docs/3.api/3.utils/set-page-layout",{"title":643,"path":644,"stem":645,"titleTemplate":6},"setResponseStatus","/docs/api/utils/set-response-status","docs/3.api/3.utils/set-response-status",{"title":647,"path":648,"stem":649,"titleTemplate":6},"showError","/docs/api/utils/show-error","docs/3.api/3.utils/show-error",{"title":651,"path":652,"stem":653,"titleTemplate":6},"updateAppConfig","/docs/api/utils/update-app-config","docs/3.api/3.utils/update-app-config",{"title":655,"titleTemplate":656,"icon":657,"path":658,"stem":659,"children":660,"page":108},"Commands","%s · Nuxt Commands","i-lucide-square-terminal","/docs/api/commands","docs/3.api/4.commands",[661,665,669,673,677,681,685,689,693,697,701,705,709,713,717],{"title":662,"path":663,"stem":664,"titleTemplate":6},"nuxi add","/docs/api/commands/add","docs/3.api/4.commands/add",{"title":666,"path":667,"stem":668,"titleTemplate":6},"nuxi analyze","/docs/api/commands/analyze","docs/3.api/4.commands/analyze",{"title":670,"path":671,"stem":672,"titleTemplate":6},"nuxi build","/docs/api/commands/build","docs/3.api/4.commands/build",{"title":674,"path":675,"stem":676,"titleTemplate":6},"nuxi build-module","/docs/api/commands/build-module","docs/3.api/4.commands/build-module",{"title":678,"path":679,"stem":680,"titleTemplate":6},"nuxi cleanup","/docs/api/commands/cleanup","docs/3.api/4.commands/cleanup",{"title":682,"path":683,"stem":684,"titleTemplate":6},"nuxi dev","/docs/api/commands/dev","docs/3.api/4.commands/dev",{"title":686,"path":687,"stem":688,"titleTemplate":6},"nuxi devtools","/docs/api/commands/devtools","docs/3.api/4.commands/devtools",{"title":690,"path":691,"stem":692,"titleTemplate":6},"nuxi generate","/docs/api/commands/generate","docs/3.api/4.commands/generate",{"title":694,"path":695,"stem":696,"titleTemplate":6},"nuxi info","/docs/api/commands/info","docs/3.api/4.commands/info",{"title":698,"path":699,"stem":700,"titleTemplate":6},"nuxi init","/docs/api/commands/init","docs/3.api/4.commands/init",{"title":702,"path":703,"stem":704,"titleTemplate":6},"nuxi module","/docs/api/commands/module","docs/3.api/4.commands/module",{"title":706,"path":707,"stem":708,"titleTemplate":6},"nuxi prepare","/docs/api/commands/prepare","docs/3.api/4.commands/prepare",{"title":710,"path":711,"stem":712,"titleTemplate":6},"nuxi preview","/docs/api/commands/preview","docs/3.api/4.commands/preview",{"title":714,"path":715,"stem":716,"titleTemplate":6},"nuxi typecheck","/docs/api/commands/typecheck","docs/3.api/4.commands/typecheck",{"title":718,"path":719,"stem":720,"titleTemplate":6},"nuxi upgrade","/docs/api/commands/upgrade","docs/3.api/4.commands/upgrade",{"title":307,"titleTemplate":722,"icon":723,"path":724,"stem":725,"children":726,"page":108},"%s · Nuxt Kit","i-lucide-package","/docs/api/kit","docs/3.api/5.kit",[727,730,733,737,741,745,749,753,757,761,765,768,771,775,779,783],{"title":143,"path":728,"stem":729,"titleTemplate":6},"/docs/api/kit/modules","docs/3.api/5.kit/1.modules",{"title":291,"path":731,"stem":732,"titleTemplate":6},"/docs/api/kit/runtime-config","docs/3.api/5.kit/10.runtime-config",{"title":734,"path":735,"stem":736,"titleTemplate":6},"Templates","/docs/api/kit/templates","docs/3.api/5.kit/10.templates",{"title":738,"path":739,"stem":740,"titleTemplate":6},"Nitro","/docs/api/kit/nitro","docs/3.api/5.kit/11.nitro",{"title":742,"path":743,"stem":744,"titleTemplate":6},"Resolving","/docs/api/kit/resolving","docs/3.api/5.kit/12.resolving",{"title":746,"path":747,"stem":748,"titleTemplate":6},"Logging","/docs/api/kit/logging","docs/3.api/5.kit/13.logging",{"title":750,"path":751,"stem":752,"titleTemplate":6},"Builder","/docs/api/kit/builder","docs/3.api/5.kit/14.builder",{"title":754,"path":755,"stem":756,"titleTemplate":6},"Examples","/docs/api/kit/examples","docs/3.api/5.kit/15.examples",{"title":758,"path":759,"stem":760,"titleTemplate":6},"Programmatic Usage","/docs/api/kit/programmatic","docs/3.api/5.kit/2.programmatic",{"title":762,"path":763,"stem":764,"titleTemplate":6},"Compatibility","/docs/api/kit/compatibility","docs/3.api/5.kit/3.compatibility",{"title":123,"path":766,"stem":767,"titleTemplate":6},"/docs/api/kit/autoimports","docs/3.api/5.kit/4.autoimports",{"title":353,"path":769,"stem":770,"titleTemplate":6},"/docs/api/kit/components","docs/3.api/5.kit/5.components",{"title":772,"path":773,"stem":774,"titleTemplate":6},"Context","/docs/api/kit/context","docs/3.api/5.kit/6.context",{"title":776,"path":777,"stem":778,"titleTemplate":6},"Pages","/docs/api/kit/pages","docs/3.api/5.kit/7.pages",{"title":780,"path":781,"stem":782,"titleTemplate":6},"Layout","/docs/api/kit/layout","docs/3.api/5.kit/8.layout",{"title":784,"path":785,"stem":786,"titleTemplate":6},"Plugins","/docs/api/kit/plugins","docs/3.api/5.kit/9.plugins",{"title":788,"titleTemplate":6,"icon":789,"path":790,"stem":791,"children":792,"page":108},"Advanced","i-lucide-brain","/docs/api/advanced","docs/3.api/6.advanced",[793,796],{"title":299,"path":794,"stem":795,"titleTemplate":6},"/docs/api/advanced/hooks","docs/3.api/6.advanced/1.hooks",{"title":797,"path":798,"stem":799,"titleTemplate":6},"Import meta","/docs/api/advanced/import-meta","docs/3.api/6.advanced/2.import-meta",{"title":801,"path":802,"stem":803,"titleTemplate":804,"icon":32},"Nuxt Configuration","/docs/api/nuxt-config","docs/3.api/6.nuxt-config","%s",{"title":754,"titleTemplate":806,"icon":807,"path":808,"stem":809,"children":810,"page":108},"%s · Nuxt Examples","i-lucide-app-window-mac","/docs/examples","docs/4.examples",[811,815,837,852,888],{"title":812,"path":813,"stem":814,"titleTemplate":6},"Hello World","/docs/examples/hello-world","docs/4.examples/0.hello-world",{"title":283,"path":816,"stem":817,"children":818,"page":108},"/docs/examples/features","docs/4.examples/1.features",[819,823,826,829,833],{"title":820,"path":821,"stem":822,"titleTemplate":6},"Auto Imports","/docs/examples/features/auto-imports","docs/4.examples/1.features/1.auto-imports",{"title":64,"path":824,"stem":825,"titleTemplate":6},"/docs/examples/features/data-fetching","docs/4.examples/1.features/2.data-fetching",{"title":69,"path":827,"stem":828,"titleTemplate":6},"/docs/examples/features/state-management","docs/4.examples/1.features/3.state-management",{"title":830,"path":831,"stem":832,"titleTemplate":6},"Meta Tags","/docs/examples/features/meta-tags","docs/4.examples/1.features/4.meta-tags",{"title":834,"path":835,"stem":836,"titleTemplate":6},"Layouts","/docs/examples/features/layouts","docs/4.examples/1.features/5.layouts",{"title":49,"path":838,"stem":839,"children":840,"page":108},"/docs/examples/routing","docs/4.examples/2.routing",[841,845,848],{"title":842,"path":843,"stem":844,"titleTemplate":6},"Middleware","/docs/examples/routing/middleware","docs/4.examples/2.routing/middleware",{"title":776,"path":846,"stem":847,"titleTemplate":6},"/docs/examples/routing/pages","docs/4.examples/2.routing/pages",{"title":849,"path":850,"stem":851,"titleTemplate":6},"Universal Router","/docs/examples/routing/universal-router","docs/4.examples/2.routing/universal-router",{"title":788,"path":853,"stem":854,"children":855,"page":108},"/docs/examples/advanced","docs/4.examples/4.advanced",[856,859,862,866,870,874,878,881,884],{"title":84,"path":857,"stem":858,"titleTemplate":6},"/docs/examples/advanced/config-extends","docs/4.examples/4.advanced/config-extends",{"title":74,"path":860,"stem":861,"titleTemplate":6},"/docs/examples/advanced/error-handling","docs/4.examples/4.advanced/error-handling",{"title":863,"path":864,"stem":865,"titleTemplate":6},"JSX / TSX","/docs/examples/advanced/jsx","docs/4.examples/4.advanced/jsx",{"title":867,"path":868,"stem":869,"titleTemplate":6},"Locale","/docs/examples/advanced/locale","docs/4.examples/4.advanced/locale",{"title":871,"path":872,"stem":873,"titleTemplate":6},"Module Extend Pages","/docs/examples/advanced/module-extend-pages","docs/4.examples/4.advanced/module-extend-pages",{"title":875,"path":876,"stem":877,"titleTemplate":6},"Teleport","/docs/examples/advanced/teleport","docs/4.examples/4.advanced/teleport",{"title":99,"path":879,"stem":880,"titleTemplate":6},"/docs/examples/advanced/testing","docs/4.examples/4.advanced/testing",{"title":436,"path":882,"stem":883,"titleTemplate":6},"/docs/examples/advanced/use-cookie","docs/4.examples/4.advanced/use-cookie",{"title":885,"path":886,"stem":887,"titleTemplate":6},"Use Custom Fetch Composable","/docs/examples/advanced/use-custom-fetch-composable","docs/4.examples/4.advanced/use-custom-fetch-composable",{"title":889,"path":890,"stem":891,"children":892,"page":108},"Experimental","/docs/examples/experimental","docs/4.examples/7.experimental",[893],{"title":894,"path":895,"stem":896,"titleTemplate":6},"WASM","/docs/examples/experimental/wasm","docs/4.examples/7.experimental/wasm",{"title":898,"titleTemplate":899,"icon":900,"path":901,"stem":902,"children":903,"page":108},"Community","%s · Nuxt Community","i-lucide-messages-square","/docs/community","docs/5.community",[904,909,914,919,924,929],{"title":905,"path":906,"stem":907,"titleTemplate":6,"icon":908},"Getting Help","/docs/community/getting-help","docs/5.community/2.getting-help","i-lucide-life-buoy",{"title":910,"path":911,"stem":912,"titleTemplate":6,"icon":913},"Reporting Bugs","/docs/community/reporting-bugs","docs/5.community/3.reporting-bugs","i-lucide-bug",{"title":915,"path":916,"stem":917,"titleTemplate":6,"icon":918},"Contribution","/docs/community/contribution","docs/5.community/4.contribution","i-lucide-git-pull-request",{"title":920,"path":921,"stem":922,"titleTemplate":6,"icon":923},"Framework","/docs/community/framework-contribution","docs/5.community/5.framework-contribution","i-lucide-github",{"title":925,"path":926,"stem":927,"titleTemplate":6,"icon":928},"Roadmap","/docs/community/roadmap","docs/5.community/6.roadmap","i-lucide-map",{"title":930,"path":931,"stem":932,"titleTemplate":6,"icon":933},"Releases","/docs/community/changelog","docs/5.community/7.changelog","i-lucide-bell-dot",{"title":935,"titleTemplate":936,"icon":937,"path":938,"stem":939,"children":940,"page":108},"Migrate to Nuxt Bridge","Migrate to Nuxt Bridge: %s","i-lucide-ship","/docs/bridge","docs/6.bridge",[941,945,948,951,955,959,963,966,969,972],{"title":942,"path":943,"stem":944,"titleTemplate":6},"Overview","/docs/bridge/overview","docs/6.bridge/1.overview",{"title":29,"path":946,"stem":947,"titleTemplate":6},"/docs/bridge/configuration","docs/6.bridge/10.configuration",{"title":151,"path":949,"stem":950,"titleTemplate":6},"/docs/bridge/typescript","docs/6.bridge/2.typescript",{"title":952,"path":953,"stem":954,"titleTemplate":6},"Legacy Composition API","/docs/bridge/bridge-composition-api","docs/6.bridge/3.bridge-composition-api",{"title":956,"path":957,"stem":958,"titleTemplate":6},"Plugins and Middleware","/docs/bridge/plugins-and-middleware","docs/6.bridge/4.plugins-and-middleware",{"title":960,"path":961,"stem":962,"titleTemplate":6},"New Composition API","/docs/bridge/nuxt3-compatible-api","docs/6.bridge/5.nuxt3-compatible-api",{"title":830,"path":964,"stem":965,"titleTemplate":6},"/docs/bridge/meta","docs/6.bridge/6.meta",{"title":291,"path":967,"stem":968,"titleTemplate":6},"/docs/bridge/runtime-config","docs/6.bridge/7.runtime-config",{"title":738,"path":970,"stem":971,"titleTemplate":6},"/docs/bridge/nitro","docs/6.bridge/8.nitro",{"title":973,"path":974,"stem":975,"titleTemplate":6},"Vite","/docs/bridge/vite","docs/6.bridge/9.vite",{"title":977,"titleTemplate":978,"icon":107,"path":979,"stem":980,"children":981,"page":108},"Migrate to Nuxt 3","Migrate to Nuxt 3: %s","/docs/migration","docs/7.migration",[982,985,989,992,995,998,1001,1004,1007,1011,1015],{"title":942,"path":983,"stem":984,"titleTemplate":6},"/docs/migration/overview","docs/7.migration/1.overview",{"title":986,"path":987,"stem":988,"titleTemplate":6},"Build Tooling","/docs/migration/bundling","docs/7.migration/10.bundling",{"title":79,"path":990,"stem":991,"titleTemplate":6},"/docs/migration/server","docs/7.migration/11.server",{"title":29,"path":993,"stem":994,"titleTemplate":6},"/docs/migration/configuration","docs/7.migration/2.configuration",{"title":143,"path":996,"stem":997,"titleTemplate":6},"/docs/migration/module-authors","docs/7.migration/20.module-authors",{"title":820,"path":999,"stem":1000,"titleTemplate":6},"/docs/migration/auto-imports","docs/7.migration/3.auto-imports",{"title":830,"path":1002,"stem":1003,"titleTemplate":6},"/docs/migration/meta","docs/7.migration/4.meta",{"title":956,"path":1005,"stem":1006,"titleTemplate":6},"/docs/migration/plugins-and-middleware","docs/7.migration/5.plugins-and-middleware",{"title":1008,"path":1009,"stem":1010,"titleTemplate":6},"Pages and Layouts","/docs/migration/pages-and-layouts","docs/7.migration/6.pages-and-layouts",{"title":1012,"path":1013,"stem":1014,"titleTemplate":6},"Component Options","/docs/migration/component-options","docs/7.migration/7.component-options",{"title":291,"path":1016,"stem":1017,"titleTemplate":6},"/docs/migration/runtime-config","docs/7.migration/8.runtime-config",{"title":1019,"path":1020,"stem":1021,"children":1022,"page":108},"Blog","/blog","blog",[1023,1027,1031,1035,1039,1043,1047,1051,1055,1059,1063,1067,1071,1075,1079,1083,1087,1091,1095,1099,1103],{"title":1024,"path":1025,"stem":1026},"Announcing 3.0","/blog/v3","blog/1.v3",{"title":1028,"path":1029,"stem":1030},"Nuxt 3.3","/blog/v3-3","blog/10.v3-3",{"title":1032,"path":1033,"stem":1034},"Nuxt 3.4","/blog/v3-4","blog/11.v3-4",{"title":1036,"path":1037,"stem":1038},"Nuxt 3.5","/blog/v3-5","blog/12.v3-5",{"title":1040,"path":1041,"stem":1042},"Nuxt 3.6","/blog/v3-6","blog/13.v3-6",{"title":1044,"path":1045,"stem":1046},"Nuxt on the Edge","/blog/nuxt-on-the-edge","blog/14.nuxt-on-the-edge",{"title":1048,"path":1049,"stem":1050},"Nuxt DevTools v1.0","/blog/nuxt-devtools-v1-0","blog/18.nuxt-devtools-v1-0",{"title":1052,"path":1053,"stem":1054},"Nuxt: A vision for 2023","/blog/vision-2023","blog/2.vision-2023",{"title":1056,"path":1057,"stem":1058},"The Evolution of Shiki v1.0","/blog/shiki-v1","blog/21.shiki-v1",{"title":1060,"path":1061,"stem":1062},"Refreshed Nuxt ESLint Integrations","/blog/eslint-module","blog/24.eslint-module",{"title":1064,"path":1065,"stem":1066},"Introducing Nuxt Scripts","/blog/nuxt-scripts","blog/26.nuxt-scripts",{"title":1068,"path":1069,"stem":1070},"Introducing Nuxt Icon v1","/blog/nuxt-icon-v1-0","blog/29.nuxt-icon-v1-0",{"title":1072,"path":1073,"stem":1074},"Introducing Nuxt DevTools","/blog/introducing-nuxt-devtools","blog/3.introducing-nuxt-devtools",{"title":1076,"path":1077,"stem":1078},"Announcing Nuxt 3 Release Candidate","/blog/nuxt3-rc","blog/3.nuxt3-rc",{"title":1080,"path":1081,"stem":1082},"Nuxt 2 End-of-Life (EOL)","/blog/nuxt2-eol","blog/4.nuxt2-eol",{"title":1084,"path":1085,"stem":1086},"Introducing Nuxt 3 Beta","/blog/nuxt3-beta","blog/4.nuxt3-beta",{"title":1088,"path":1089,"stem":1090},"Going Full Static","/blog/going-full-static","blog/5.going-full-static",{"title":1092,"path":1093,"stem":1094},"Introducing Smart Prefetching","/blog/introducing-smart-prefetching","blog/6.introducing-smart-prefetching",{"title":1096,"path":1097,"stem":1098},"Understanding how fetch works in Nuxt 2.12","/blog/understanding-how-fetch-works-in-nuxt-2-12","blog/7.understanding-how-fetch-works-in-nuxt-2-12",{"title":1100,"path":1101,"stem":1102},"Nuxt 2 Static Improvements","/blog/nuxt-static-improvements","blog/8.nuxt-static-improvements",{"title":1104,"path":1105,"stem":1106},"Nuxt 2: From Terminal to Browser","/blog/nuxtjs-from-terminal-to-browser","blog/9.nuxtjs-from-terminal-to-browser",{"id":1108,"title":1109,"authors":1110,"body":1116,"category":2635,"date":2636,"description":2637,"draft":108,"extension":2638,"image":2639,"meta":2640,"navigation":108,"path":2641,"seo":2642,"stem":2643,"tags":6,"__hash__":2644},"blog/blog/31.v3-16.md","Nuxt 3.16",[1111],{"name":1112,"avatar":1113,"to":1115},"Daniel Roe",{"src":1114},"https://github.com/danielroe.png","https://bsky.app/profile/danielroe.dev",{"type":1117,"value":1118,"toc":2617},"minimal",[1119,1123,1128,1144,1150,1153,1178,1185,1200,1215,1219,1230,1240,1363,1366,1385,1388,1400,1404,1413,1416,1419,1427,1431,1434,1497,1500,1515,1530,1534,1548,1719,1726,1757,1764,1768,1777,1847,1851,1864,2009,2016,2020,2029,2075,2221,2225,2245,2248,2301,2308,2312,2320,2336,2345,2348,2352,2363,2501,2505,2508,2516,2524,2527,2559,2563,2566,2587,2590,2594,2607,2610,2613],[1120,1121,1122],"p",{},"There's a lot in this one!",[1124,1125,1127],"h2",{"id":1126},"️-a-new-new-nuxt","⚡️ A New New Nuxt",[1120,1129,1130,1131,1135,1136,1143],{},"Say hello to ",[1132,1133,1134],"code",{},"create-nuxt",", a new tool for starting Nuxt projects (big thanks to ",[1137,1138,1142],"a",{"href":1139,"rel":1140},"https://github.com/devgar",[1141],"nofollow","@devgar"," for donating the package name)!",[1120,1145,1146,1147,1149],{},"It's a streamlined version of ",[1132,1148,698],{}," - just a sixth of the size and bundled as a single file with all dependencies inlined, to get you going as fast as possible.",[1120,1151,1152],{},"Starting a new project is as simple as:",[1154,1155,1160],"pre",{"className":1156,"code":1157,"language":1158,"meta":1159,"style":1159},"language-bash shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","npm create nuxt\n","bash","",[1132,1161,1162],{"__ignoreMap":1159},[1163,1164,1167,1171,1175],"span",{"class":1165,"line":1166},"line",1,[1163,1168,1170],{"class":1169},"sT2Ow","npm",[1163,1172,1174],{"class":1173},"s5UST"," create",[1163,1176,1177],{"class":1173}," nuxt\n",[1120,1179,1180],{},[1181,1182],"img",{"alt":1183,"src":1184},"screenshot of create nuxt app","https://cdn.bsky.app/img/feed_thumbnail/plain/did:plc:qrygjljnajqwxbld3k7uvyms/bafkreifkhnzbwxgkgjw6jpqg6j6z6abylvfyynca3r7jh5b63fcromj2ia@jpeg",[1120,1186,1187,1188,1193,1194,1199],{},"Special thanks to ",[1137,1189,1192],{"href":1190,"rel":1191},"https://github.com/cmang",[1141],"@cmang"," for the ",[1137,1195,1198],{"href":1196,"rel":1197},"https://bsky.app/profile/durdraw.org/post/3liadod3gv22a",[1141],"beautiful ASCII-art",". ❤️",[1120,1201,1202,1203,1208,1209,1214],{},"Want to learn more about where we're headed with the Nuxt CLI? Check out our roadmap ",[1137,1204,1207],{"href":1205,"rel":1206},"https://github.com/nuxt/cli/issues/648",[1141],"here",", including our plans for an ",[1137,1210,1213],{"href":1211,"rel":1212},"https://github.com/nuxt/cli/issues/754",[1141],"interactive modules selector",".",[1124,1216,1218],{"id":1217},"unhead-v2","🚀 Unhead v2",[1120,1220,1221,1222,1225,1226,1229],{},"We've upgraded to ",[1132,1223,1224],{},"unhead"," v2, the engine behind Nuxt's ",[1132,1227,1228],{},"\u003Chead>"," management. This major version removes deprecations and improves how context works:",[1231,1232,1233,1237],"ul",{},[1234,1235,1236],"li",{},"For Nuxt 3 users, we're shipping a legacy compatibility build so nothing breaks",[1234,1238,1239],{},"The context implementation is now more direct via Nuxt itself",[1154,1241,1245],{"className":1242,"code":1243,"language":1244,"meta":1159,"style":1159},"language-ts shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","// Nuxt now re-exports composables while properly resolving the context\nexport function useHead(input, options = {}) {\n  const unhead = injectHead(options.nuxt)\n  return head(input, { head: unhead, ...options })\n}\n","ts",[1132,1246,1247,1253,1291,1320,1357],{"__ignoreMap":1159},[1163,1248,1249],{"class":1165,"line":1166},[1163,1250,1252],{"class":1251},"svXlt","// Nuxt now re-exports composables while properly resolving the context\n",[1163,1254,1256,1260,1264,1268,1272,1276,1279,1282,1285,1288],{"class":1165,"line":1255},2,[1163,1257,1259],{"class":1258},"sFVN2","export",[1163,1261,1263],{"class":1262},"sRBFq"," function",[1163,1265,1267],{"class":1266},"szd4z"," useHead",[1163,1269,1271],{"class":1270},"sYp4K","(",[1163,1273,1275],{"class":1274},"ssYd4","input",[1163,1277,1278],{"class":1270},",",[1163,1280,1281],{"class":1274}," options",[1163,1283,1284],{"class":1270}," =",[1163,1286,1287],{"class":1270}," {})",[1163,1289,1290],{"class":1270}," {\n",[1163,1292,1294,1297,1301,1303,1306,1309,1312,1314,1317],{"class":1165,"line":1293},3,[1163,1295,1296],{"class":1262},"  const",[1163,1298,1300],{"class":1299},"spdxX"," unhead",[1163,1302,1284],{"class":1270},[1163,1304,1305],{"class":1266}," injectHead",[1163,1307,1271],{"class":1308},"sQ5dg",[1163,1310,1311],{"class":1299},"options",[1163,1313,1214],{"class":1270},[1163,1315,1316],{"class":1299},"nuxt",[1163,1318,1319],{"class":1308},")\n",[1163,1321,1323,1326,1329,1331,1333,1335,1338,1340,1343,1345,1347,1350,1352,1355],{"class":1165,"line":1322},4,[1163,1324,1325],{"class":1258},"  return",[1163,1327,1328],{"class":1266}," head",[1163,1330,1271],{"class":1308},[1163,1332,1275],{"class":1299},[1163,1334,1278],{"class":1270},[1163,1336,1337],{"class":1270}," {",[1163,1339,1328],{"class":1308},[1163,1341,1342],{"class":1270},":",[1163,1344,1300],{"class":1299},[1163,1346,1278],{"class":1270},[1163,1348,1349],{"class":1270}," ...",[1163,1351,1311],{"class":1299},[1163,1353,1354],{"class":1270}," }",[1163,1356,1319],{"class":1308},[1163,1358,1360],{"class":1165,"line":1359},5,[1163,1361,1362],{"class":1270},"}\n",[1120,1364,1365],{},"If you're using Unhead directly in your app, keep in mind:",[1367,1368,1369,1379],"ol",{},[1234,1370,1371,1372,1375,1376],{},"Import from Nuxt's auto-imports or ",[1132,1373,1374],{},"#app/composables/head"," instead of ",[1132,1377,1378],{},"@unhead/vue",[1234,1380,1381,1382,1384],{},"Importing directly from ",[1132,1383,1378],{}," might lose async context",[1120,1386,1387],{},"Don't worry though - we've maintained backward compatibility in Nuxt 3, so most users won't need to change anything!",[1120,1389,1390,1391,1394,1395,1399],{},"If you've opted into ",[1132,1392,1393],{},"compatibilityVersion: 4",", check out ",[1137,1396,1398],{"href":1397},"/docs/getting-started/upgrade#unhead-v2","our upgrade guide"," for additional changes.",[1124,1401,1403],{"id":1402},"devtools-v2-upgrade","🔧 Devtools v2 Upgrade",[1120,1405,1406,1407,1412],{},"Nuxt Devtools has leveled up to v2 (",[1137,1408,1411],{"href":1409,"rel":1410},"https://github.com/nuxt/nuxt/pull/30889",[1141],"#30889",")!",[1120,1414,1415],{},"You'll love the new features like custom editor selection, Discovery.js for inspecting resolved configs (perfect for debugging), the return of the schema generator, and slimmer dependencies.",[1120,1417,1418],{},"One of our favorite improvements is the ability to track how modules modify your Nuxt configuration - giving you X-ray vision into what's happening under the hood.",[1120,1420,1421,1422,1214],{},"👉 Discover all the details in the ",[1137,1423,1426],{"href":1424,"rel":1425},"https://github.com/nuxt/devtools/releases",[1141],"Nuxt DevTools release notes",[1124,1428,1430],{"id":1429},"️-performance-improvements","⚡️ Performance Improvements",[1120,1432,1433],{},"We're continuing to make Nuxt faster, and there are a number of improvements in v3.16:",[1367,1435,1436,1453,1462,1471,1484],{},[1234,1437,1438,1439,1446,1447,1452],{},"Using ",[1137,1440,1443],{"href":1441,"rel":1442},"https://github.com/unjs/exsolve",[1141],[1132,1444,1445],{},"exsolve"," for module resolution (",[1137,1448,1451],{"href":1449,"rel":1450},"https://github.com/nuxt/nuxt/pull/31124",[1141],"#31124",") along with the rest of the unjs ecosystem (nitro, c12, pkg-types, and more) - which dramatically speeds up module resolution",[1234,1454,1455,1456,1461],{},"Smarter module resolution paths (",[1137,1457,1460],{"href":1458,"rel":1459},"https://github.com/nuxt/nuxt/pull/31037",[1141],"#31037",") - prioritizes direct imports for better efficiency",[1234,1463,1464,1465,1470],{},"Eliminated duplicated Nitro alias resolution (",[1137,1466,1469],{"href":1467,"rel":1468},"https://github.com/nuxt/nuxt/pull/31088",[1141],"#31088",") - leaner file handling",[1234,1472,1473,1474,1477,1478,1483],{},"Streamlined ",[1132,1475,1476],{},"loadNuxt"," by skipping unnecessary resolution steps (",[1137,1479,1482],{"href":1480,"rel":1481},"https://github.com/nuxt/nuxt/pull/31176",[1141],"#31176",") - faster startups",[1234,1485,1486,1487,1490,1491,1496],{},"Adopt ",[1132,1488,1489],{},"oxc-parser"," for parsing in Nuxt plugins (",[1137,1492,1495],{"href":1493,"rel":1494},"https://github.com/nuxt/nuxt/pull/30066",[1141],"#30066",")",[1120,1498,1499],{},"All these speed boosts happen automatically - no configuration needed!",[1120,1501,1502,1503,1508,1509,1514],{},"Shout out to ",[1137,1504,1507],{"href":1505,"rel":1506},"https://codspeed.io/",[1141],"CodSpeed"," with ",[1137,1510,1513],{"href":1511,"rel":1512},"https://vitest.dev/guide/features.html#benchmarking",[1141],"Vitest benchmarking"," to measure these improvements in CI - it has been really helpful.",[1120,1516,1517,1518,1523,1524,1529],{},"To add some anecdotal evidence, my personal site at ",[1137,1519,1522],{"href":1520,"rel":1521},"https://github.com/danielroe/roe.dev",[1141],"roe.dev"," loads 32% faster with v3.16, and ",[1137,1525,1528],{"href":1526,"rel":1527},"https://github.com/nuxt/nuxt.com",[1141],"nuxt.com"," is 28% faster. I hope you see similar results! ⚡️",[1124,1531,1533],{"id":1532},"️-delayed-hydration-support","🕰️ Delayed Hydration Support",[1120,1535,1536,1537,1542,1543,1214],{},"We're very pleased to bring you native delayed/lazy hydration support (",[1137,1538,1541],{"href":1539,"rel":1540},"https://github.com/nuxt/nuxt/pull/26468",[1141],"#26468",")! This lets you control exactly when components hydrate, which can improve initial load performance and time-to-interactive. We're leveraging Vue's built-in hydration strategies - ",[1137,1544,1547],{"href":1545,"rel":1546},"https://vuejs.org/guide/components/async.html#lazy-hydration",[1141],"check them out in the Vue docs",[1154,1549,1553],{"className":1550,"code":1551,"language":1552,"meta":1159,"style":1159},"language-vue shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","\u003Ctemplate>\n  \u003C!-- Hydrate when component becomes visible in viewport -->\n  \u003CLazyExpensiveComponent hydrate-on-visible />\n  \n  \u003C!-- Hydrate when browser is idle -->\n  \u003CLazyHeavyComponent hydrate-on-idle />\n  \n  \u003C!-- Hydrate on interaction (mouseover in this case) -->\n  \u003CLazyDropdown hydrate-on-interaction=\"mouseover\" />\n  \n  \u003C!-- Hydrate when media query matches -->\n  \u003CLazyMobileMenu hydrate-on-media-query=\"(max-width: 768px)\" />\n  \n  \u003C!-- Hydrate after a specific delay in milliseconds -->\n  \u003CLazyFooter :hydrate-after=\"2000\" />\n\u003C/template>\n","vue",[1132,1554,1555,1566,1571,1585,1590,1595,1608,1613,1619,1643,1648,1654,1676,1681,1687,1709],{"__ignoreMap":1159},[1163,1556,1557,1560,1563],{"class":1165,"line":1166},[1163,1558,1559],{"class":1270},"\u003C",[1163,1561,1562],{"class":1308},"template",[1163,1564,1565],{"class":1270},">\n",[1163,1567,1568],{"class":1165,"line":1255},[1163,1569,1570],{"class":1251},"  \u003C!-- Hydrate when component becomes visible in viewport -->\n",[1163,1572,1573,1576,1579,1582],{"class":1165,"line":1293},[1163,1574,1575],{"class":1270},"  \u003C",[1163,1577,1578],{"class":1308},"LazyExpensiveComponent",[1163,1580,1581],{"class":1262}," hydrate-on-visible",[1163,1583,1584],{"class":1270}," />\n",[1163,1586,1587],{"class":1165,"line":1322},[1163,1588,1589],{"class":1299},"  \n",[1163,1591,1592],{"class":1165,"line":1359},[1163,1593,1594],{"class":1251},"  \u003C!-- Hydrate when browser is idle -->\n",[1163,1596,1598,1600,1603,1606],{"class":1165,"line":1597},6,[1163,1599,1575],{"class":1270},[1163,1601,1602],{"class":1308},"LazyHeavyComponent",[1163,1604,1605],{"class":1262}," hydrate-on-idle",[1163,1607,1584],{"class":1270},[1163,1609,1611],{"class":1165,"line":1610},7,[1163,1612,1589],{"class":1299},[1163,1614,1616],{"class":1165,"line":1615},8,[1163,1617,1618],{"class":1251},"  \u003C!-- Hydrate on interaction (mouseover in this case) -->\n",[1163,1620,1622,1624,1627,1630,1633,1636,1639,1641],{"class":1165,"line":1621},9,[1163,1623,1575],{"class":1270},[1163,1625,1626],{"class":1308},"LazyDropdown",[1163,1628,1629],{"class":1262}," hydrate-on-interaction",[1163,1631,1632],{"class":1270},"=",[1163,1634,1635],{"class":1270},"\"",[1163,1637,1638],{"class":1173},"mouseover",[1163,1640,1635],{"class":1270},[1163,1642,1584],{"class":1270},[1163,1644,1646],{"class":1165,"line":1645},10,[1163,1647,1589],{"class":1299},[1163,1649,1651],{"class":1165,"line":1650},11,[1163,1652,1653],{"class":1251},"  \u003C!-- Hydrate when media query matches -->\n",[1163,1655,1657,1659,1662,1665,1667,1669,1672,1674],{"class":1165,"line":1656},12,[1163,1658,1575],{"class":1270},[1163,1660,1661],{"class":1308},"LazyMobileMenu",[1163,1663,1664],{"class":1262}," hydrate-on-media-query",[1163,1666,1632],{"class":1270},[1163,1668,1635],{"class":1270},[1163,1670,1671],{"class":1173},"(max-width: 768px)",[1163,1673,1635],{"class":1270},[1163,1675,1584],{"class":1270},[1163,1677,1679],{"class":1165,"line":1678},13,[1163,1680,1589],{"class":1299},[1163,1682,1684],{"class":1165,"line":1683},14,[1163,1685,1686],{"class":1251},"  \u003C!-- Hydrate after a specific delay in milliseconds -->\n",[1163,1688,1690,1692,1695,1698,1700,1702,1705,1707],{"class":1165,"line":1689},15,[1163,1691,1575],{"class":1270},[1163,1693,1694],{"class":1308},"LazyFooter",[1163,1696,1697],{"class":1262}," :hydrate-after",[1163,1699,1632],{"class":1270},[1163,1701,1635],{"class":1270},[1163,1703,1704],{"class":1173},"2000",[1163,1706,1635],{"class":1270},[1163,1708,1584],{"class":1270},[1163,1710,1712,1715,1717],{"class":1165,"line":1711},16,[1163,1713,1714],{"class":1270},"\u003C/",[1163,1716,1562],{"class":1308},[1163,1718,1565],{"class":1270},[1120,1720,1721,1722,1725],{},"You can also listen for when hydration happens with the ",[1132,1723,1724],{},"@hydrated"," event:",[1154,1727,1729],{"className":1550,"code":1728,"language":1552,"meta":1159,"style":1159},"\u003CLazyComponent hydrate-on-visible @hydrated=\"onComponentHydrated\" />\n",[1132,1730,1731],{"__ignoreMap":1159},[1163,1732,1733,1735,1738,1740,1743,1746,1748,1750,1753,1755],{"class":1165,"line":1166},[1163,1734,1559],{"class":1270},[1163,1736,1737],{"class":1308},"LazyComponent",[1163,1739,1581],{"class":1262},[1163,1741,1742],{"class":1270}," @",[1163,1744,1745],{"class":1262},"hydrated",[1163,1747,1632],{"class":1270},[1163,1749,1635],{"class":1270},[1163,1751,1752],{"class":1299},"onComponentHydrated",[1163,1754,1635],{"class":1270},[1163,1756,1584],{"class":1270},[1120,1758,1759,1760,1214],{},"Learn more about lazy hydration in ",[1137,1761,1763],{"href":1762},"/docs/guide/directory-structure/components#delayed-or-lazy-hydration","our components documentation",[1124,1765,1767],{"id":1766},"advanced-pages-configuration","🧩 Advanced Pages Configuration",[1120,1769,1770,1771,1776],{},"You can now fine-tune which files Nuxt scans for pages (",[1137,1772,1775],{"href":1773,"rel":1774},"https://github.com/nuxt/nuxt/pull/31090",[1141],"#31090","), giving you more control over your project structure:",[1154,1778,1780],{"className":1242,"code":1779,"filename":260,"language":1244,"meta":1159,"style":1159},"export default defineNuxtConfig({\n  pages: {\n    // Filter specific files or directories\n    pattern: ['**/*.vue'],\n  }\n})\n",[1132,1781,1782,1797,1806,1811,1835,1840],{"__ignoreMap":1159},[1163,1783,1784,1786,1789,1792,1794],{"class":1165,"line":1166},[1163,1785,1259],{"class":1258},[1163,1787,1788],{"class":1258}," default",[1163,1790,1791],{"class":1266}," defineNuxtConfig",[1163,1793,1271],{"class":1299},[1163,1795,1796],{"class":1270},"{\n",[1163,1798,1799,1802,1804],{"class":1165,"line":1255},[1163,1800,1801],{"class":1308},"  pages",[1163,1803,1342],{"class":1270},[1163,1805,1290],{"class":1270},[1163,1807,1808],{"class":1165,"line":1293},[1163,1809,1810],{"class":1251},"    // Filter specific files or directories\n",[1163,1812,1813,1816,1818,1821,1824,1827,1829,1832],{"class":1165,"line":1322},[1163,1814,1815],{"class":1308},"    pattern",[1163,1817,1342],{"class":1270},[1163,1819,1820],{"class":1299}," [",[1163,1822,1823],{"class":1270},"'",[1163,1825,1826],{"class":1173},"**/*.vue",[1163,1828,1823],{"class":1270},[1163,1830,1831],{"class":1299},"]",[1163,1833,1834],{"class":1270},",\n",[1163,1836,1837],{"class":1165,"line":1359},[1163,1838,1839],{"class":1270},"  }\n",[1163,1841,1842,1845],{"class":1165,"line":1597},[1163,1843,1844],{"class":1270},"}",[1163,1846,1319],{"class":1299},[1124,1848,1850],{"id":1849},"enhanced-debugging","🔍 Enhanced Debugging",[1120,1852,1853,1854,1857,1858,1863],{},"We've made debugging with the ",[1132,1855,1856],{},"debug"," option more flexible! Now you can enable just the debug logs you need (",[1137,1859,1862],{"href":1860,"rel":1861},"https://github.com/nuxt/nuxt/pull/30578",[1141],"#30578","):",[1154,1865,1867],{"className":1242,"code":1866,"filename":260,"language":1244,"meta":1159,"style":1159},"export default defineNuxtConfig({\n  debug: {\n    // Enable specific debugging features\n    templates: true,\n    modules: true,\n    watchers: true,\n    hooks: {\n      client: true,\n      server: true,\n    },\n    nitro: true,\n    router: true,\n    hydration: true,\n  }\n})\n",[1132,1868,1869,1881,1890,1895,1908,1919,1930,1939,1950,1961,1966,1977,1988,1999,2003],{"__ignoreMap":1159},[1163,1870,1871,1873,1875,1877,1879],{"class":1165,"line":1166},[1163,1872,1259],{"class":1258},[1163,1874,1788],{"class":1258},[1163,1876,1791],{"class":1266},[1163,1878,1271],{"class":1299},[1163,1880,1796],{"class":1270},[1163,1882,1883,1886,1888],{"class":1165,"line":1255},[1163,1884,1885],{"class":1308},"  debug",[1163,1887,1342],{"class":1270},[1163,1889,1290],{"class":1270},[1163,1891,1892],{"class":1165,"line":1293},[1163,1893,1894],{"class":1251},"    // Enable specific debugging features\n",[1163,1896,1897,1900,1902,1906],{"class":1165,"line":1322},[1163,1898,1899],{"class":1308},"    templates",[1163,1901,1342],{"class":1270},[1163,1903,1905],{"class":1904},"sagxc"," true",[1163,1907,1834],{"class":1270},[1163,1909,1910,1913,1915,1917],{"class":1165,"line":1359},[1163,1911,1912],{"class":1308},"    modules",[1163,1914,1342],{"class":1270},[1163,1916,1905],{"class":1904},[1163,1918,1834],{"class":1270},[1163,1920,1921,1924,1926,1928],{"class":1165,"line":1597},[1163,1922,1923],{"class":1308},"    watchers",[1163,1925,1342],{"class":1270},[1163,1927,1905],{"class":1904},[1163,1929,1834],{"class":1270},[1163,1931,1932,1935,1937],{"class":1165,"line":1610},[1163,1933,1934],{"class":1308},"    hooks",[1163,1936,1342],{"class":1270},[1163,1938,1290],{"class":1270},[1163,1940,1941,1944,1946,1948],{"class":1165,"line":1615},[1163,1942,1943],{"class":1308},"      client",[1163,1945,1342],{"class":1270},[1163,1947,1905],{"class":1904},[1163,1949,1834],{"class":1270},[1163,1951,1952,1955,1957,1959],{"class":1165,"line":1621},[1163,1953,1954],{"class":1308},"      server",[1163,1956,1342],{"class":1270},[1163,1958,1905],{"class":1904},[1163,1960,1834],{"class":1270},[1163,1962,1963],{"class":1165,"line":1645},[1163,1964,1965],{"class":1270},"    },\n",[1163,1967,1968,1971,1973,1975],{"class":1165,"line":1650},[1163,1969,1970],{"class":1308},"    nitro",[1163,1972,1342],{"class":1270},[1163,1974,1905],{"class":1904},[1163,1976,1834],{"class":1270},[1163,1978,1979,1982,1984,1986],{"class":1165,"line":1656},[1163,1980,1981],{"class":1308},"    router",[1163,1983,1342],{"class":1270},[1163,1985,1905],{"class":1904},[1163,1987,1834],{"class":1270},[1163,1989,1990,1993,1995,1997],{"class":1165,"line":1678},[1163,1991,1992],{"class":1308},"    hydration",[1163,1994,1342],{"class":1270},[1163,1996,1905],{"class":1904},[1163,1998,1834],{"class":1270},[1163,2000,2001],{"class":1165,"line":1683},[1163,2002,1839],{"class":1270},[1163,2004,2005,2007],{"class":1165,"line":1689},[1163,2006,1844],{"class":1270},[1163,2008,1319],{"class":1299},[1120,2010,2011,2012,2015],{},"Or keep it simple with ",[1132,2013,2014],{},"debug: true"," to enable all these debugging features.",[1124,2017,2019],{"id":2018},"decorators-support","🎨 Decorators Support",[1120,2021,2022,2023,2028],{},"For the decorator fans out there (whoever you are!), we've added experimental support (",[1137,2024,2027],{"href":2025,"rel":2026},"https://github.com/nuxt/nuxt/pull/27672",[1141],"#27672","). As with all experimental features, feedback is much appreciated.",[1154,2030,2032],{"className":1242,"code":2031,"filename":260,"language":1244,"meta":1159,"style":1159},"export default defineNuxtConfig({\n  experimental: {\n    decorators: true\n  }\n})\n",[1132,2033,2034,2046,2055,2065,2069],{"__ignoreMap":1159},[1163,2035,2036,2038,2040,2042,2044],{"class":1165,"line":1166},[1163,2037,1259],{"class":1258},[1163,2039,1788],{"class":1258},[1163,2041,1791],{"class":1266},[1163,2043,1271],{"class":1299},[1163,2045,1796],{"class":1270},[1163,2047,2048,2051,2053],{"class":1165,"line":1255},[1163,2049,2050],{"class":1308},"  experimental",[1163,2052,1342],{"class":1270},[1163,2054,1290],{"class":1270},[1163,2056,2057,2060,2062],{"class":1165,"line":1293},[1163,2058,2059],{"class":1308},"    decorators",[1163,2061,1342],{"class":1270},[1163,2063,2064],{"class":1904}," true\n",[1163,2066,2067],{"class":1165,"line":1322},[1163,2068,1839],{"class":1270},[1163,2070,2071,2073],{"class":1165,"line":1359},[1163,2072,1844],{"class":1270},[1163,2074,1319],{"class":1299},[1154,2076,2078],{"className":1242,"code":2077,"language":1244,"meta":1159,"style":1159},"function something (_method: () => unknown) {\n  return () => 'decorated'\n}\n\nclass SomeClass {\n  @something\n  public someMethod () {\n    return 'initial'\n  }\n}\n\nconst value = new SomeClass().someMethod()\n// returns 'decorated'\n",[1132,2079,2080,2109,2126,2130,2136,2146,2154,2166,2178,2182,2186,2190,2216],{"__ignoreMap":1159},[1163,2081,2082,2085,2088,2091,2094,2096,2099,2102,2105,2107],{"class":1165,"line":1166},[1163,2083,2084],{"class":1262},"function",[1163,2086,2087],{"class":1266}," something",[1163,2089,2090],{"class":1270}," (",[1163,2092,2093],{"class":1266},"_method",[1163,2095,1342],{"class":1270},[1163,2097,2098],{"class":1270}," ()",[1163,2100,2101],{"class":1262}," =>",[1163,2103,2104],{"class":1169}," unknown",[1163,2106,1496],{"class":1270},[1163,2108,1290],{"class":1270},[1163,2110,2111,2113,2115,2117,2120,2123],{"class":1165,"line":1255},[1163,2112,1325],{"class":1258},[1163,2114,2098],{"class":1270},[1163,2116,2101],{"class":1262},[1163,2118,2119],{"class":1270}," '",[1163,2121,2122],{"class":1173},"decorated",[1163,2124,2125],{"class":1270},"'\n",[1163,2127,2128],{"class":1165,"line":1293},[1163,2129,1362],{"class":1270},[1163,2131,2132],{"class":1165,"line":1322},[1163,2133,2135],{"emptyLinePlaceholder":2134},true,"\n",[1163,2137,2138,2141,2144],{"class":1165,"line":1359},[1163,2139,2140],{"class":1262},"class",[1163,2142,2143],{"class":1169}," SomeClass",[1163,2145,1290],{"class":1270},[1163,2147,2148,2151],{"class":1165,"line":1597},[1163,2149,2150],{"class":1270},"  @",[1163,2152,2153],{"class":1299},"something\n",[1163,2155,2156,2159,2162,2164],{"class":1165,"line":1610},[1163,2157,2158],{"class":1262},"  public",[1163,2160,2161],{"class":1308}," someMethod",[1163,2163,2098],{"class":1270},[1163,2165,1290],{"class":1270},[1163,2167,2168,2171,2173,2176],{"class":1165,"line":1615},[1163,2169,2170],{"class":1258},"    return",[1163,2172,2119],{"class":1270},[1163,2174,2175],{"class":1173},"initial",[1163,2177,2125],{"class":1270},[1163,2179,2180],{"class":1165,"line":1621},[1163,2181,1839],{"class":1270},[1163,2183,2184],{"class":1165,"line":1645},[1163,2185,1362],{"class":1270},[1163,2187,2188],{"class":1165,"line":1650},[1163,2189,2135],{"emptyLinePlaceholder":2134},[1163,2191,2192,2195,2198,2200,2203,2205,2208,2210,2213],{"class":1165,"line":1656},[1163,2193,2194],{"class":1262},"const",[1163,2196,2197],{"class":1299}," value ",[1163,2199,1632],{"class":1270},[1163,2201,2202],{"class":1270}," new",[1163,2204,2143],{"class":1266},[1163,2206,2207],{"class":1299},"()",[1163,2209,1214],{"class":1270},[1163,2211,2212],{"class":1266},"someMethod",[1163,2214,2215],{"class":1299},"()\n",[1163,2217,2218],{"class":1165,"line":1678},[1163,2219,2220],{"class":1251},"// returns 'decorated'\n",[1124,2222,2224],{"id":2223},"named-layer-aliases","📛 Named Layer Aliases",[1120,2226,2227,2228,2231,2232,2235,2236,2090,2239,2244],{},"It's been much requested, and it's here! Auto-scanned local layers (from your ",[1132,2229,2230],{},"~~/layers"," directory) now automatically create aliases. You can access your ",[1132,2233,2234],{},"~~/layers/test"," layer via ",[1132,2237,2238],{},"#layers/test",[1137,2240,2243],{"href":2241,"rel":2242},"https://github.com/nuxt/nuxt/pull/30948",[1141],"#30948",") - no configuration needed.",[1120,2246,2247],{},"If you want named aliases for other layers, you can add a name to your layer configuration:",[1154,2249,2251],{"className":1242,"code":2250,"filename":260,"language":1244,"meta":1159,"style":1159},"export default defineNuxtConfig({\n  $meta: {\n    name: 'example-layer',\n  },\n})\n",[1132,2252,2253,2265,2274,2290,2295],{"__ignoreMap":1159},[1163,2254,2255,2257,2259,2261,2263],{"class":1165,"line":1166},[1163,2256,1259],{"class":1258},[1163,2258,1788],{"class":1258},[1163,2260,1791],{"class":1266},[1163,2262,1271],{"class":1299},[1163,2264,1796],{"class":1270},[1163,2266,2267,2270,2272],{"class":1165,"line":1255},[1163,2268,2269],{"class":1308},"  $meta",[1163,2271,1342],{"class":1270},[1163,2273,1290],{"class":1270},[1163,2275,2276,2279,2281,2283,2286,2288],{"class":1165,"line":1293},[1163,2277,2278],{"class":1308},"    name",[1163,2280,1342],{"class":1270},[1163,2282,2119],{"class":1270},[1163,2284,2285],{"class":1173},"example-layer",[1163,2287,1823],{"class":1270},[1163,2289,1834],{"class":1270},[1163,2291,2292],{"class":1165,"line":1322},[1163,2293,2294],{"class":1270},"  },\n",[1163,2296,2297,2299],{"class":1165,"line":1359},[1163,2298,1844],{"class":1270},[1163,2300,1319],{"class":1299},[1120,2302,2303,2304,2307],{},"This creates the alias ",[1132,2305,2306],{},"#layers/example-layer"," pointing to your layer - making imports cleaner and more intuitive.",[1124,2309,2311],{"id":2310},"error-handling-improvements","🧪 Error Handling Improvements",[1120,2313,2314,2315,1863],{},"We've greatly improved error messages and source tracking (",[1137,2316,2319],{"href":2317,"rel":2318},"https://github.com/nuxt/nuxt/pull/31144",[1141],"#31144",[1367,2321,2322,2328],{},[1234,2323,2324,2325,2327],{},"Better warnings for undefined ",[1132,2326,432],{}," calls with precise file location information",[1234,2329,2330,2331,1496],{},"Error pages now appear correctly on island page errors (",[1137,2332,2335],{"href":2333,"rel":2334},"https://github.com/nuxt/nuxt/pull/31081",[1141],"#31081",[1120,2337,2338,2339,2344],{},"Plus, we're now using Nitro's beautiful error handling (powered by ",[1137,2340,2343],{"href":2341,"rel":2342},"https://github.com/poppinss/youch",[1141],"youch",") to provide more helpful error messages in the terminal, complete with stacktrace support.",[1120,2346,2347],{},"Nitro now also automatically applies source maps without requiring extra Node options, and we set appropriate security headers when rendering error pages.",[1124,2349,2351],{"id":2350},"module-development-improvements","📦 Module Development Improvements",[1120,2353,2354,2355,2090,2358,1863],{},"For module authors, we've added the ability to augment Nitro types with ",[1132,2356,2357],{},"addTypeTemplate",[1137,2359,2362],{"href":2360,"rel":2361},"https://github.com/nuxt/nuxt/pull/31079",[1141],"#31079",[1154,2364,2366],{"className":1242,"code":2365,"language":1244,"meta":1159,"style":1159},"// Inside your Nuxt module\nexport default defineNuxtModule({\n  setup(options, nuxt) {\n    addTypeTemplate({\n      filename: 'types/my-module.d.ts',\n      getContents: () => `\n        declare module 'nitropack' {\n          interface NitroRouteConfig {\n            myCustomOption?: boolean\n          }\n        }\n      `\n    }, { nitro: true })\n  }\n})\n",[1132,2367,2368,2373,2386,2404,2413,2429,2443,2448,2453,2458,2463,2468,2473,2491,2495],{"__ignoreMap":1159},[1163,2369,2370],{"class":1165,"line":1166},[1163,2371,2372],{"class":1251},"// Inside your Nuxt module\n",[1163,2374,2375,2377,2379,2382,2384],{"class":1165,"line":1255},[1163,2376,1259],{"class":1258},[1163,2378,1788],{"class":1258},[1163,2380,2381],{"class":1266}," defineNuxtModule",[1163,2383,1271],{"class":1299},[1163,2385,1796],{"class":1270},[1163,2387,2388,2391,2393,2395,2397,2400,2402],{"class":1165,"line":1293},[1163,2389,2390],{"class":1308},"  setup",[1163,2392,1271],{"class":1270},[1163,2394,1311],{"class":1274},[1163,2396,1278],{"class":1270},[1163,2398,2399],{"class":1274}," nuxt",[1163,2401,1496],{"class":1270},[1163,2403,1290],{"class":1270},[1163,2405,2406,2409,2411],{"class":1165,"line":1322},[1163,2407,2408],{"class":1266},"    addTypeTemplate",[1163,2410,1271],{"class":1308},[1163,2412,1796],{"class":1270},[1163,2414,2415,2418,2420,2422,2425,2427],{"class":1165,"line":1359},[1163,2416,2417],{"class":1308},"      filename",[1163,2419,1342],{"class":1270},[1163,2421,2119],{"class":1270},[1163,2423,2424],{"class":1173},"types/my-module.d.ts",[1163,2426,1823],{"class":1270},[1163,2428,1834],{"class":1270},[1163,2430,2431,2434,2436,2438,2440],{"class":1165,"line":1597},[1163,2432,2433],{"class":1266},"      getContents",[1163,2435,1342],{"class":1270},[1163,2437,2098],{"class":1270},[1163,2439,2101],{"class":1262},[1163,2441,2442],{"class":1270}," `\n",[1163,2444,2445],{"class":1165,"line":1610},[1163,2446,2447],{"class":1173},"        declare module 'nitropack' {\n",[1163,2449,2450],{"class":1165,"line":1615},[1163,2451,2452],{"class":1173},"          interface NitroRouteConfig {\n",[1163,2454,2455],{"class":1165,"line":1621},[1163,2456,2457],{"class":1173},"            myCustomOption?: boolean\n",[1163,2459,2460],{"class":1165,"line":1645},[1163,2461,2462],{"class":1173},"          }\n",[1163,2464,2465],{"class":1165,"line":1650},[1163,2466,2467],{"class":1173},"        }\n",[1163,2469,2470],{"class":1165,"line":1656},[1163,2471,2472],{"class":1270},"      `\n",[1163,2474,2475,2478,2480,2483,2485,2487,2489],{"class":1165,"line":1678},[1163,2476,2477],{"class":1270},"    },",[1163,2479,1337],{"class":1270},[1163,2481,2482],{"class":1308}," nitro",[1163,2484,1342],{"class":1270},[1163,2486,1905],{"class":1904},[1163,2488,1354],{"class":1270},[1163,2490,1319],{"class":1308},[1163,2492,2493],{"class":1165,"line":1683},[1163,2494,1839],{"class":1270},[1163,2496,2497,2499],{"class":1165,"line":1689},[1163,2498,1844],{"class":1270},[1163,2500,1319],{"class":1299},[1124,2502,2504],{"id":2503},"️-nitro-v211-upgrade","⚙️ Nitro v2.11 Upgrade",[1120,2506,2507],{},"We've upgraded to Nitro v2.11. There are so many improvements - more than I can cover in these brief release notes.",[1120,2509,2510,2511,1214],{},"👉 Check out all the details in the ",[1137,2512,2515],{"href":2513,"rel":2514},"https://github.com/nitrojs/nitro/releases/tag/v2.11.0",[1141],"Nitro v2.11.0 release notes",[1124,2517,2519,2520,2523],{"id":2518},"new-unjs-major-versions","📦 New ",[1132,2521,2522],{},"unjs"," Major Versions",[1120,2525,2526],{},"This release includes several major version upgrades from the unjs ecosystem, focused on performance and smaller bundle sizes through ESM-only distributions:",[1231,2528,2529,2532,2535,2538,2541,2544,2547,2550,2553,2556],{},[1234,2530,2531],{},"unenv upgraded to v2 (full rewrite)",[1234,2533,2534],{},"db0 upgraded to v0.3 (ESM-only, native node:sql, improvements)",[1234,2536,2537],{},"ohash upgraded to v2 (ESM-only, native node:crypto support, much faster)",[1234,2539,2540],{},"untyped upgraded to v2 (ESM-only, smaller install size)",[1234,2542,2543],{},"unimport upgraded to v4 (improvements)",[1234,2545,2546],{},"c12 upgraded to v3 (ESM-only)",[1234,2548,2549],{},"pathe upgraded to v2 (ESM-only)",[1234,2551,2552],{},"cookie-es upgraded to v2 (ESM-only)",[1234,2554,2555],{},"esbuild upgraded to v0.25",[1234,2557,2558],{},"chokidar upgraded to v4",[1124,2560,2562],{"id":2561},"upgrading","✅ Upgrading",[1120,2564,2565],{},"As usual, our recommendation for upgrading is to run:",[1154,2567,2571],{"className":2568,"code":2569,"language":2570,"meta":1159,"style":1159},"language-sh shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","npx nuxi@latest upgrade --dedupe\n","sh",[1132,2572,2573],{"__ignoreMap":1159},[1163,2574,2575,2578,2581,2584],{"class":1165,"line":1166},[1163,2576,2577],{"class":1169},"npx",[1163,2579,2580],{"class":1173}," nuxi@latest",[1163,2582,2583],{"class":1173}," upgrade",[1163,2585,2586],{"class":1173}," --dedupe\n",[1120,2588,2589],{},"This refreshes your lockfile and pulls in all the latest dependencies that Nuxt relies on, especially from the unjs ecosystem.",[1124,2591,2593],{"id":2592},"full-release-notes","Full release notes",[2595,2596,2601],"read-more",{"color":2597,"icon":2598,"target":2599,"to":2600},"gray","i-simple-icons-github","_blank","https://github.com/nuxt/nuxt/releases/tag/v3.16.0",[1120,2602,2603,2604,1214],{},"Read the full release notes of Nuxt ",[1132,2605,2606],{},"v3.16.0",[1120,2608,2609],{},"A huge thank you to everyone who's been a part of this release. ❤️",[1120,2611,2612],{},"I'm aware there have been lots of very significant changes in this release - please don't hesitate to let us know if you have any feedback or issues! 🙏",[2614,2615,2616],"style",{},"html pre.shiki code .sT2Ow, html code.shiki .sT2Ow{--shiki-light:#E2931D;--shiki-default:#E2931D;--shiki-dark:#FFCB6B}html pre.shiki code .s5UST, html code.shiki .s5UST{--shiki-light:#91B859;--shiki-default:#91B859;--shiki-dark:#C3E88D}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .svXlt, html code.shiki .svXlt{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#90A4AE;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .sFVN2, html code.shiki .sFVN2{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#39ADB5;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .sRBFq, html code.shiki .sRBFq{--shiki-light:#9C3EDA;--shiki-default:#9C3EDA;--shiki-dark:#C792EA}html pre.shiki code .szd4z, html code.shiki .szd4z{--shiki-light:#6182B8;--shiki-default:#6182B8;--shiki-dark:#82AAFF}html pre.shiki code .sYp4K, html code.shiki .sYp4K{--shiki-light:#39ADB5;--shiki-default:#39ADB5;--shiki-dark:#89DDFF}html pre.shiki code .ssYd4, html code.shiki .ssYd4{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#90A4AE;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .spdxX, html code.shiki .spdxX{--shiki-light:#90A4AE;--shiki-default:#90A4AE;--shiki-dark:#BABED8}html pre.shiki code .sQ5dg, html code.shiki .sQ5dg{--shiki-light:#E53935;--shiki-default:#E53935;--shiki-dark:#F07178}html pre.shiki code .sagxc, html code.shiki .sagxc{--shiki-light:#FF5370;--shiki-default:#FF5370;--shiki-dark:#FF9CAC}",{"title":1159,"searchDepth":1255,"depth":1255,"links":2618},[2619,2620,2621,2622,2623,2624,2625,2626,2627,2628,2629,2630,2631,2633,2634],{"id":1126,"depth":1255,"text":1127},{"id":1217,"depth":1255,"text":1218},{"id":1402,"depth":1255,"text":1403},{"id":1429,"depth":1255,"text":1430},{"id":1532,"depth":1255,"text":1533},{"id":1766,"depth":1255,"text":1767},{"id":1849,"depth":1255,"text":1850},{"id":2018,"depth":1255,"text":2019},{"id":2223,"depth":1255,"text":2224},{"id":2310,"depth":1255,"text":2311},{"id":2350,"depth":1255,"text":2351},{"id":2503,"depth":1255,"text":2504},{"id":2518,"depth":1255,"text":2632},"📦 New unjs Major Versions",{"id":2561,"depth":1255,"text":2562},{"id":2592,"depth":1255,"text":2593},"Release","2025-03-07T10:00:00.000Z","Nuxt 3.16 is out - with packed with features and performance improvements","md","/assets/blog/v3.16.png",{},"/blog/v3-16",{"title":1109,"description":2637},"blog/31.v3-16","fvwOKKbujP",[6,6],1742571309786]