[{"data":1,"prerenderedAt":6375},["ShallowReactive",2],{"$fGCo9l1hMtNdUiA6QzdUX5X3kLqaWcC5t2kdz4LrvCvc":3,"versions":2842,"-docs-3-x-directory-structure-components":2846,"-docs-3-x-directory-structure-components-surround":6370},[4,1120,1940,2753],{"title":5,"titleTemplate":6,"icon":7,"path":8,"stem":9,"children":10,"page":108},"Docs",null,"i-lucide-book-marked","/docs/3.x","docs/3.x",[11,109,246,426,907,999,1036,1078],{"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/3.x/getting-started","docs/3.x/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/3.x/getting-started/introduction","docs/3.x/1.getting-started/01.introduction","i-lucide-info",{"title":24,"path":25,"stem":26,"titleTemplate":6,"icon":27},"Installation","/docs/3.x/getting-started/installation","docs/3.x/1.getting-started/02.installation","i-lucide-play",{"title":29,"path":30,"stem":31,"titleTemplate":6,"icon":32},"Configuration","/docs/3.x/getting-started/configuration","docs/3.x/1.getting-started/03.configuration","i-lucide-cog",{"title":34,"path":35,"stem":36,"titleTemplate":6,"icon":37},"Views","/docs/3.x/getting-started/views","docs/3.x/1.getting-started/04.views","i-lucide-panels-top-left",{"title":39,"path":40,"stem":41,"titleTemplate":6,"icon":42},"Assets","/docs/3.x/getting-started/assets","docs/3.x/1.getting-started/05.assets","i-lucide-image",{"title":44,"path":45,"stem":46,"titleTemplate":6,"icon":47},"Styling","/docs/3.x/getting-started/styling","docs/3.x/1.getting-started/06.styling","i-lucide-palette",{"title":49,"path":50,"stem":51,"titleTemplate":6,"icon":52},"Routing","/docs/3.x/getting-started/routing","docs/3.x/1.getting-started/07.routing","i-lucide-milestone",{"title":54,"path":55,"stem":56,"titleTemplate":6,"icon":57},"SEO and Meta","/docs/3.x/getting-started/seo-meta","docs/3.x/1.getting-started/08.seo-meta","i-lucide-file-search",{"title":59,"path":60,"stem":61,"titleTemplate":6,"icon":62},"Transitions","/docs/3.x/getting-started/transitions","docs/3.x/1.getting-started/09.transitions","i-lucide-toggle-right",{"title":64,"path":65,"stem":66,"titleTemplate":6,"icon":67},"Data Fetching","/docs/3.x/getting-started/data-fetching","docs/3.x/1.getting-started/10.data-fetching","i-lucide-cable",{"title":69,"path":70,"stem":71,"titleTemplate":6,"icon":72},"State Management","/docs/3.x/getting-started/state-management","docs/3.x/1.getting-started/11.state-management","i-lucide-database",{"title":74,"path":75,"stem":76,"titleTemplate":6,"icon":77},"Error Handling","/docs/3.x/getting-started/error-handling","docs/3.x/1.getting-started/12.error-handling","i-lucide-bug-off",{"title":79,"path":80,"stem":81,"titleTemplate":6,"icon":82},"Server","/docs/3.x/getting-started/server","docs/3.x/1.getting-started/13.server","i-lucide-pc-case",{"title":84,"path":85,"stem":86,"titleTemplate":6,"icon":87},"Layers","/docs/3.x/getting-started/layers","docs/3.x/1.getting-started/14.layers","i-lucide-layers",{"title":89,"path":90,"stem":91,"titleTemplate":6,"icon":92},"Prerendering","/docs/3.x/getting-started/prerendering","docs/3.x/1.getting-started/15.prerendering","i-lucide-file-code-2",{"title":94,"path":95,"stem":96,"titleTemplate":6,"icon":97},"Deployment","/docs/3.x/getting-started/deployment","docs/3.x/1.getting-started/16.deployment","i-lucide-cloud",{"title":99,"path":100,"stem":101,"titleTemplate":6,"icon":102},"Testing","/docs/3.x/getting-started/testing","docs/3.x/1.getting-started/17.testing","i-lucide-circle-check",{"title":104,"path":105,"stem":106,"titleTemplate":6,"icon":107},"Upgrade Guide","/docs/3.x/getting-started/upgrade","docs/3.x/1.getting-started/18.upgrade","i-lucide-circle-arrow-up",false,{"title":110,"titleTemplate":111,"icon":112,"path":113,"stem":114,"children":115,"page":108},"Directory Structure","%s · Nuxt Directory Structure","i-vscode-icons-default-folder","/docs/3.x/directory-structure","docs/3.x/2.directory-structure",[116,121,126,131,136,141,146,151,156,161,165,170,174,179,184,189,194,199,204,209,214,218,223,228,232,236,241],{"title":117,"path":118,"stem":119,"titleTemplate":6,"icon":120},".nuxt","/docs/3.x/directory-structure/nuxt","docs/3.x/2.directory-structure/0.nuxt","i-vscode-icons-folder-type-temp",{"title":122,"path":123,"stem":124,"titleTemplate":6,"icon":125},".output","/docs/3.x/directory-structure/output","docs/3.x/2.directory-structure/0.output","i-vscode-icons-folder-type-package",{"title":127,"path":128,"stem":129,"titleTemplate":6,"icon":130},"assets","/docs/3.x/directory-structure/assets","docs/3.x/2.directory-structure/1.assets","i-vscode-icons-folder-type-asset",{"title":132,"path":133,"stem":134,"titleTemplate":6,"icon":135},"components","/docs/3.x/directory-structure/components","docs/3.x/2.directory-structure/1.components","i-vscode-icons-folder-type-component",{"title":137,"path":138,"stem":139,"titleTemplate":6,"icon":140},"composables","/docs/3.x/directory-structure/composables","docs/3.x/2.directory-structure/1.composables","i-vscode-icons-folder-type-src",{"title":142,"path":143,"stem":144,"titleTemplate":6,"icon":145},"content","/docs/3.x/directory-structure/content","docs/3.x/2.directory-structure/1.content","i-vscode-icons-folder-type-log",{"title":147,"path":148,"stem":149,"titleTemplate":6,"icon":150},"layers","/docs/3.x/directory-structure/layers","docs/3.x/2.directory-structure/1.layers","i-vscode-icons-folder-type-nuxt",{"title":152,"path":153,"stem":154,"titleTemplate":6,"icon":155},"layouts","/docs/3.x/directory-structure/layouts","docs/3.x/2.directory-structure/1.layouts","i-vscode-icons-folder-type-view",{"title":157,"path":158,"stem":159,"titleTemplate":6,"icon":160},"middleware","/docs/3.x/directory-structure/middleware","docs/3.x/2.directory-structure/1.middleware","i-vscode-icons-folder-type-middleware",{"title":162,"path":163,"stem":164,"titleTemplate":6,"icon":150},"modules","/docs/3.x/directory-structure/modules","docs/3.x/2.directory-structure/1.modules",{"title":166,"path":167,"stem":168,"titleTemplate":6,"icon":169},"node_modules","/docs/3.x/directory-structure/node_modules","docs/3.x/2.directory-structure/1.node_modules","i-vscode-icons-folder-type-node",{"title":171,"path":172,"stem":173,"titleTemplate":6,"icon":155},"pages","/docs/3.x/directory-structure/pages","docs/3.x/2.directory-structure/1.pages",{"title":175,"path":176,"stem":177,"titleTemplate":6,"icon":178},"plugins","/docs/3.x/directory-structure/plugins","docs/3.x/2.directory-structure/1.plugins","i-vscode-icons-folder-type-plugin",{"title":180,"path":181,"stem":182,"titleTemplate":6,"icon":183},"public","/docs/3.x/directory-structure/public","docs/3.x/2.directory-structure/1.public","i-vscode-icons-folder-type-public",{"title":185,"path":186,"stem":187,"titleTemplate":6,"icon":188},"server","/docs/3.x/directory-structure/server","docs/3.x/2.directory-structure/1.server","i-vscode-icons-folder-type-server",{"title":190,"path":191,"stem":192,"titleTemplate":6,"icon":193},"shared","/docs/3.x/directory-structure/shared","docs/3.x/2.directory-structure/1.shared","i-vscode-icons-folder-type-shared",{"title":195,"path":196,"stem":197,"titleTemplate":6,"icon":198},"utils","/docs/3.x/directory-structure/utils","docs/3.x/2.directory-structure/1.utils","i-vscode-icons-folder-type-tools",{"title":200,"path":201,"stem":202,"titleTemplate":6,"icon":203},".env","/docs/3.x/directory-structure/env","docs/3.x/2.directory-structure/2.env","i-vscode-icons-file-type-dotenv",{"title":205,"path":206,"stem":207,"titleTemplate":6,"icon":208},".gitignore","/docs/3.x/directory-structure/gitignore","docs/3.x/2.directory-structure/2.gitignore","i-vscode-icons-file-type-git",{"title":210,"path":211,"stem":212,"titleTemplate":6,"icon":213},".nuxtignore","/docs/3.x/directory-structure/nuxtignore","docs/3.x/2.directory-structure/2.nuxtignore","i-vscode-icons-file-type-nuxt",{"title":215,"path":216,"stem":217,"titleTemplate":6,"icon":213},".nuxtrc","/docs/3.x/directory-structure/nuxtrc","docs/3.x/2.directory-structure/2.nuxtrc",{"title":219,"path":220,"stem":221,"titleTemplate":6,"icon":222},"app.vue","/docs/3.x/directory-structure/app","docs/3.x/2.directory-structure/3.app","i-vscode-icons-file-type-vue",{"title":224,"path":225,"stem":226,"titleTemplate":6,"icon":227},"app.config.ts","/docs/3.x/directory-structure/app-config","docs/3.x/2.directory-structure/3.app-config","i-vscode-icons-file-type-light-config",{"title":229,"path":230,"stem":231,"titleTemplate":6,"icon":222},"error.vue","/docs/3.x/directory-structure/error","docs/3.x/2.directory-structure/3.error",{"title":233,"path":234,"stem":235,"titleTemplate":6,"icon":213},"nuxt.config.ts","/docs/3.x/directory-structure/nuxt-config","docs/3.x/2.directory-structure/3.nuxt-config",{"title":237,"path":238,"stem":239,"titleTemplate":6,"icon":240},"package.json","/docs/3.x/directory-structure/package","docs/3.x/2.directory-structure/3.package","i-vscode-icons-file-type-npm",{"title":242,"path":243,"stem":244,"titleTemplate":6,"icon":245},"tsconfig.json","/docs/3.x/directory-structure/tsconfig","docs/3.x/2.directory-structure/3.tsconfig","i-vscode-icons-file-type-tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":249,"stem":250,"children":251,"page":108},"Guide","i-lucide-book-open","/docs/3.x/guide","docs/3.x/3.guide",[252,287,306,321,356,379],{"title":253,"titleTemplate":254,"icon":255,"path":256,"stem":257,"children":258,"page":108},"Key Concepts","%s · Nuxt Concepts","i-lucide-medal","/docs/3.x/guide/concepts","docs/3.x/3.guide/1.concepts",[259,263,267,271,275,279,283],{"title":260,"path":261,"stem":262,"titleTemplate":6},"Rendering Modes","/docs/3.x/guide/concepts/rendering","docs/3.x/3.guide/1.concepts/1.rendering",{"title":264,"path":265,"stem":266,"titleTemplate":6},"Nuxt Lifecycle","/docs/3.x/guide/concepts/nuxt-lifecycle","docs/3.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":269,"stem":270,"titleTemplate":6},"Auto-imports","/docs/3.x/guide/concepts/auto-imports","docs/3.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":273,"stem":274,"titleTemplate":6},"Server Engine","/docs/3.x/guide/concepts/server-engine","docs/3.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":277,"stem":278,"titleTemplate":6},"Modules","/docs/3.x/guide/concepts/modules","docs/3.x/3.guide/1.concepts/5.modules",{"title":280,"path":281,"stem":282,"titleTemplate":6},"TypeScript","/docs/3.x/guide/concepts/typescript","docs/3.x/3.guide/1.concepts/8.typescript",{"title":284,"path":285,"stem":286,"titleTemplate":6},"Code Style","/docs/3.x/guide/concepts/code-style","docs/3.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":291,"stem":292,"children":293,"page":108},"Best Practices","%s · Best Practices","i-lucide-square-check","/docs/3.x/guide/best-practices","docs/3.x/3.guide/2.best-practices",[294,298,302],{"title":295,"path":296,"stem":297,"titleTemplate":6},"Nuxt and hydration","/docs/3.x/guide/best-practices/hydration","docs/3.x/3.guide/2.best-practices/hydration",{"title":299,"path":300,"stem":301,"titleTemplate":6},"Nuxt Performance","/docs/3.x/guide/best-practices/performance","docs/3.x/3.guide/2.best-practices/performance",{"title":303,"path":304,"stem":305,"titleTemplate":6},"Nuxt Plugins","/docs/3.x/guide/best-practices/plugins","docs/3.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":310,"stem":311,"children":312,"page":108},"Working with AI","Working with AI: %s","i-lucide-bot","/docs/3.x/guide/ai","docs/3.x/3.guide/3.ai",[313,317],{"title":314,"path":315,"stem":316,"titleTemplate":6},"MCP Server","/docs/3.x/guide/ai/mcp","docs/3.x/3.guide/3.ai/1.mcp",{"title":318,"path":319,"stem":320,"titleTemplate":6},"LLMs.txt","/docs/3.x/guide/ai/llms-txt","docs/3.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":325,"stem":326,"children":327,"page":108},"Module Author Guide","%s · Nuxt Modules Author Guide","i-lucide-box","/docs/3.x/guide/modules","docs/3.x/3.guide/4.modules",[328,332,336,340,344,348,352],{"title":329,"path":330,"stem":331,"titleTemplate":6},"Create Your First Module","/docs/3.x/guide/modules/getting-started","docs/3.x/3.guide/4.modules/1.getting-started",{"title":333,"path":334,"stem":335,"titleTemplate":6},"Understand Module Structure","/docs/3.x/guide/modules/module-anatomy","docs/3.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":338,"stem":339,"titleTemplate":6},"Add Plugins, Components & More","/docs/3.x/guide/modules/recipes-basics","docs/3.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":342,"stem":343,"titleTemplate":6},"Use Hooks & Extend Types","/docs/3.x/guide/modules/recipes-advanced","docs/3.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":346,"stem":347,"titleTemplate":6},"Test Your Module","/docs/3.x/guide/modules/testing","docs/3.x/3.guide/4.modules/5.testing",{"title":349,"path":350,"stem":351,"titleTemplate":6},"Follow Best Practices","/docs/3.x/guide/modules/best-practices","docs/3.x/3.guide/4.modules/6.best-practices",{"title":353,"path":354,"stem":355,"titleTemplate":6},"Publish & Share Your Module","/docs/3.x/guide/modules/ecosystem","docs/3.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":360,"stem":361,"children":362,"page":108},"Recipes","%s · Recipes","i-lucide-cooking-pot","/docs/3.x/guide/recipes","docs/3.x/3.guide/5.recipes",[363,367,371,375],{"title":364,"path":365,"stem":366,"titleTemplate":6},"Custom Routing","/docs/3.x/guide/recipes/custom-routing","docs/3.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":369,"stem":370,"titleTemplate":6},"Vite Plugins","/docs/3.x/guide/recipes/vite-plugin","docs/3.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":373,"stem":374,"titleTemplate":6},"Custom useFetch","/docs/3.x/guide/recipes/custom-usefetch","docs/3.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":377,"stem":378,"titleTemplate":6},"Sessions and Authentication","/docs/3.x/guide/recipes/sessions-and-authentication","docs/3.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":383,"stem":384,"children":385,"page":108},"Going Further","%s · Nuxt Advanced","i-lucide-star","/docs/3.x/guide/going-further","docs/3.x/3.guide/6.going-further",[386,390,394,398,402,406,410,414,418,422],{"title":387,"path":388,"stem":389,"titleTemplate":6},"Custom Events","/docs/3.x/guide/going-further/events","docs/3.x/3.guide/6.going-further/1.events",{"title":391,"path":392,"stem":393,"titleTemplate":6},"Experimental Features","/docs/3.x/guide/going-further/experimental-features","docs/3.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":396,"stem":397,"titleTemplate":6},"Features","/docs/3.x/guide/going-further/features","docs/3.x/3.guide/6.going-further/1.features",{"title":399,"path":400,"stem":401,"titleTemplate":6},"Runtime Config","/docs/3.x/guide/going-further/runtime-config","docs/3.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":404,"stem":405,"titleTemplate":6},"Nightly Release Channel","/docs/3.x/guide/going-further/nightly-release-channel","docs/3.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":408,"stem":409,"titleTemplate":6},"Lifecycle Hooks","/docs/3.x/guide/going-further/hooks","docs/3.x/3.guide/6.going-further/2.hooks",{"title":411,"path":412,"stem":413,"titleTemplate":6},"Nuxt Kit","/docs/3.x/guide/going-further/kit","docs/3.x/3.guide/6.going-further/4.kit",{"title":415,"path":416,"stem":417,"titleTemplate":6},"NuxtApp","/docs/3.x/guide/going-further/nuxt-app","docs/3.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":420,"stem":421,"titleTemplate":6},"Authoring Nuxt Layers","/docs/3.x/guide/going-further/layers","docs/3.x/3.guide/6.going-further/7.layers",{"title":423,"path":424,"stem":425,"titleTemplate":6},"Debugging","/docs/3.x/guide/going-further/debugging","docs/3.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":430,"stem":431,"children":432,"page":108},"API","%s · Nuxt API","i-lucide-code-xml","/docs/3.x/api","docs/3.x/4.api",[433,499,622,745,816,889,902],{"title":434,"titleTemplate":435,"icon":324,"path":436,"stem":437,"children":438,"page":108},"Components","%s · Nuxt Components","/docs/3.x/api/components","docs/3.x/4.api/1.components",[439,443,447,451,455,459,463,467,471,475,479,483,487,491,495],{"title":440,"path":441,"stem":442,"titleTemplate":6},"\u003CClientOnly>","/docs/3.x/api/components/client-only","docs/3.x/4.api/1.components/1.client-only",{"title":444,"path":445,"stem":446,"titleTemplate":6},"\u003CDevOnly>","/docs/3.x/api/components/dev-only","docs/3.x/4.api/1.components/1.dev-only",{"title":448,"path":449,"stem":450,"titleTemplate":6},"\u003CNuxtClientFallback>","/docs/3.x/api/components/nuxt-client-fallback","docs/3.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":453,"stem":454,"titleTemplate":6},"\u003CNuxtPicture>","/docs/3.x/api/components/nuxt-picture","docs/3.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":457,"stem":458,"titleTemplate":6},"\u003CTeleport>","/docs/3.x/api/components/teleports","docs/3.x/4.api/1.components/11.teleports",{"title":460,"path":461,"stem":462,"titleTemplate":6},"\u003CNuxtRouteAnnouncer>","/docs/3.x/api/components/nuxt-route-announcer","docs/3.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":465,"stem":466,"titleTemplate":6},"\u003CNuxtTime>","/docs/3.x/api/components/nuxt-time","docs/3.x/4.api/1.components/13.nuxt-time",{"title":468,"path":469,"stem":470,"titleTemplate":6},"\u003CNuxtPage>","/docs/3.x/api/components/nuxt-page","docs/3.x/4.api/1.components/2.nuxt-page",{"title":472,"path":473,"stem":474,"titleTemplate":6},"\u003CNuxtLayout>","/docs/3.x/api/components/nuxt-layout","docs/3.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":477,"stem":478,"titleTemplate":6},"\u003CNuxtLink>","/docs/3.x/api/components/nuxt-link","docs/3.x/4.api/1.components/4.nuxt-link",{"title":480,"path":481,"stem":482,"titleTemplate":6},"\u003CNuxtLoadingIndicator>","/docs/3.x/api/components/nuxt-loading-indicator","docs/3.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":485,"stem":486,"titleTemplate":6},"\u003CNuxtErrorBoundary>","/docs/3.x/api/components/nuxt-error-boundary","docs/3.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":489,"stem":490,"titleTemplate":6},"\u003CNuxtWelcome>","/docs/3.x/api/components/nuxt-welcome","docs/3.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":493,"stem":494,"titleTemplate":6},"\u003CNuxtIsland>","/docs/3.x/api/components/nuxt-island","docs/3.x/4.api/1.components/8.nuxt-island",{"title":496,"path":497,"stem":498,"titleTemplate":6},"\u003CNuxtImg>","/docs/3.x/api/components/nuxt-img","docs/3.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":503,"stem":504,"children":505,"page":108},"Composables","%s · Nuxt Composables","i-lucide-arrow-left-right","/docs/3.x/api/composables","docs/3.x/4.api/2.composables",[506,510,514,518,522,526,530,534,538,542,546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618],{"title":507,"path":508,"stem":509,"titleTemplate":6},"onPrehydrate","/docs/3.x/api/composables/on-prehydrate","docs/3.x/4.api/2.composables/on-prehydrate",{"title":511,"path":512,"stem":513,"titleTemplate":6},"useAppConfig","/docs/3.x/api/composables/use-app-config","docs/3.x/4.api/2.composables/use-app-config",{"title":515,"path":516,"stem":517,"titleTemplate":6},"useAsyncData","/docs/3.x/api/composables/use-async-data","docs/3.x/4.api/2.composables/use-async-data",{"title":519,"path":520,"stem":521,"titleTemplate":6},"useCookie","/docs/3.x/api/composables/use-cookie","docs/3.x/4.api/2.composables/use-cookie",{"title":523,"path":524,"stem":525,"titleTemplate":6},"useError","/docs/3.x/api/composables/use-error","docs/3.x/4.api/2.composables/use-error",{"title":527,"path":528,"stem":529,"titleTemplate":6},"useFetch","/docs/3.x/api/composables/use-fetch","docs/3.x/4.api/2.composables/use-fetch",{"title":531,"path":532,"stem":533,"titleTemplate":6},"useHead","/docs/3.x/api/composables/use-head","docs/3.x/4.api/2.composables/use-head",{"title":535,"path":536,"stem":537,"titleTemplate":6},"useHeadSafe","/docs/3.x/api/composables/use-head-safe","docs/3.x/4.api/2.composables/use-head-safe",{"title":539,"path":540,"stem":541,"titleTemplate":6},"useHydration","/docs/3.x/api/composables/use-hydration","docs/3.x/4.api/2.composables/use-hydration",{"title":543,"path":544,"stem":545,"titleTemplate":6},"useLazyAsyncData","/docs/3.x/api/composables/use-lazy-async-data","docs/3.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":548,"stem":549,"titleTemplate":6},"useLazyFetch","/docs/3.x/api/composables/use-lazy-fetch","docs/3.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":552,"stem":553,"titleTemplate":6},"useLoadingIndicator","/docs/3.x/api/composables/use-loading-indicator","docs/3.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":556,"stem":557,"titleTemplate":6},"useNuxtApp","/docs/3.x/api/composables/use-nuxt-app","docs/3.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":560,"stem":561,"titleTemplate":6},"useNuxtData","/docs/3.x/api/composables/use-nuxt-data","docs/3.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":564,"stem":565,"titleTemplate":6},"usePreviewMode","/docs/3.x/api/composables/use-preview-mode","docs/3.x/4.api/2.composables/use-preview-mode",{"title":567,"path":568,"stem":569,"titleTemplate":6},"useRequestEvent","/docs/3.x/api/composables/use-request-event","docs/3.x/4.api/2.composables/use-request-event",{"title":571,"path":572,"stem":573,"titleTemplate":6},"useRequestFetch","/docs/3.x/api/composables/use-request-fetch","docs/3.x/4.api/2.composables/use-request-fetch",{"title":575,"path":576,"stem":577,"titleTemplate":6},"useRequestHeader","/docs/3.x/api/composables/use-request-header","docs/3.x/4.api/2.composables/use-request-header",{"title":579,"path":580,"stem":581,"titleTemplate":6},"useRequestHeaders","/docs/3.x/api/composables/use-request-headers","docs/3.x/4.api/2.composables/use-request-headers",{"title":583,"path":584,"stem":585,"titleTemplate":6},"useRequestURL","/docs/3.x/api/composables/use-request-url","docs/3.x/4.api/2.composables/use-request-url",{"title":587,"path":588,"stem":589,"titleTemplate":6},"useResponseHeader","/docs/3.x/api/composables/use-response-header","docs/3.x/4.api/2.composables/use-response-header",{"title":591,"path":592,"stem":593,"titleTemplate":6},"useRoute","/docs/3.x/api/composables/use-route","docs/3.x/4.api/2.composables/use-route",{"title":595,"path":596,"stem":597,"titleTemplate":6},"useRouteAnnouncer","/docs/3.x/api/composables/use-route-announcer","docs/3.x/4.api/2.composables/use-route-announcer",{"title":599,"path":600,"stem":601,"titleTemplate":6},"useRouter","/docs/3.x/api/composables/use-router","docs/3.x/4.api/2.composables/use-router",{"title":603,"path":604,"stem":605,"titleTemplate":6},"useRuntimeConfig","/docs/3.x/api/composables/use-runtime-config","docs/3.x/4.api/2.composables/use-runtime-config",{"title":607,"path":608,"stem":609,"titleTemplate":6},"useRuntimeHook","/docs/3.x/api/composables/use-runtime-hook","docs/3.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":612,"stem":613,"titleTemplate":6},"useSeoMeta","/docs/3.x/api/composables/use-seo-meta","docs/3.x/4.api/2.composables/use-seo-meta",{"title":615,"path":616,"stem":617,"titleTemplate":6},"useServerSeoMeta","/docs/3.x/api/composables/use-server-seo-meta","docs/3.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":620,"stem":621,"titleTemplate":6},"useState","/docs/3.x/api/composables/use-state","docs/3.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":626,"stem":627,"children":628,"page":108},"Utils","%s · Nuxt Utils","i-lucide-square-function","/docs/3.x/api/utils","docs/3.x/4.api/3.utils",[629,633,637,641,645,649,653,657,661,665,669,673,677,681,685,689,693,697,701,705,709,713,717,721,725,729,733,737,741],{"title":630,"path":631,"stem":632,"titleTemplate":6},"$fetch","/docs/3.x/api/utils/dollarfetch","docs/3.x/4.api/3.utils/$fetch",{"title":634,"path":635,"stem":636,"titleTemplate":6},"abortNavigation","/docs/3.x/api/utils/abort-navigation","docs/3.x/4.api/3.utils/abort-navigation",{"title":638,"path":639,"stem":640,"titleTemplate":6},"addRouteMiddleware","/docs/3.x/api/utils/add-route-middleware","docs/3.x/4.api/3.utils/add-route-middleware",{"title":642,"path":643,"stem":644,"titleTemplate":6},"callOnce","/docs/3.x/api/utils/call-once","docs/3.x/4.api/3.utils/call-once",{"title":646,"path":647,"stem":648,"titleTemplate":6},"clearError","/docs/3.x/api/utils/clear-error","docs/3.x/4.api/3.utils/clear-error",{"title":650,"path":651,"stem":652,"titleTemplate":6},"clearNuxtData","/docs/3.x/api/utils/clear-nuxt-data","docs/3.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":655,"stem":656,"titleTemplate":6},"clearNuxtState","/docs/3.x/api/utils/clear-nuxt-state","docs/3.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":659,"stem":660,"titleTemplate":6},"createError","/docs/3.x/api/utils/create-error","docs/3.x/4.api/3.utils/create-error",{"title":662,"path":663,"stem":664,"titleTemplate":6},"defineLazyHydrationComponent","/docs/3.x/api/utils/define-lazy-hydration-component","docs/3.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":667,"stem":668,"titleTemplate":6},"defineNuxtComponent","/docs/3.x/api/utils/define-nuxt-component","docs/3.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":671,"stem":672,"titleTemplate":6},"defineNuxtPlugin","/docs/3.x/api/utils/define-nuxt-plugin","docs/3.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":675,"stem":676,"titleTemplate":6},"defineNuxtRouteMiddleware","/docs/3.x/api/utils/define-nuxt-route-middleware","docs/3.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":679,"stem":680,"titleTemplate":6},"definePageMeta","/docs/3.x/api/utils/define-page-meta","docs/3.x/4.api/3.utils/define-page-meta",{"title":682,"path":683,"stem":684,"titleTemplate":6},"defineRouteRules","/docs/3.x/api/utils/define-route-rules","docs/3.x/4.api/3.utils/define-route-rules",{"title":686,"path":687,"stem":688,"titleTemplate":6},"navigateTo","/docs/3.x/api/utils/navigate-to","docs/3.x/4.api/3.utils/navigate-to",{"title":690,"path":691,"stem":692,"titleTemplate":6},"onBeforeRouteLeave","/docs/3.x/api/utils/on-before-route-leave","docs/3.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":695,"stem":696,"titleTemplate":6},"onBeforeRouteUpdate","/docs/3.x/api/utils/on-before-route-update","docs/3.x/4.api/3.utils/on-before-route-update",{"title":698,"path":699,"stem":700,"titleTemplate":6},"onNuxtReady","/docs/3.x/api/utils/on-nuxt-ready","docs/3.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":703,"stem":704,"titleTemplate":6},"prefetchComponents","/docs/3.x/api/utils/prefetch-components","docs/3.x/4.api/3.utils/prefetch-components",{"title":706,"path":707,"stem":708,"titleTemplate":6},"preloadComponents","/docs/3.x/api/utils/preload-components","docs/3.x/4.api/3.utils/preload-components",{"title":710,"path":711,"stem":712,"titleTemplate":6},"preloadRouteComponents","/docs/3.x/api/utils/preload-route-components","docs/3.x/4.api/3.utils/preload-route-components",{"title":714,"path":715,"stem":716,"titleTemplate":6},"prerenderRoutes","/docs/3.x/api/utils/prerender-routes","docs/3.x/4.api/3.utils/prerender-routes",{"title":718,"path":719,"stem":720,"titleTemplate":6},"refreshCookie","/docs/3.x/api/utils/refresh-cookie","docs/3.x/4.api/3.utils/refresh-cookie",{"title":722,"path":723,"stem":724,"titleTemplate":6},"refreshNuxtData","/docs/3.x/api/utils/refresh-nuxt-data","docs/3.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":727,"stem":728,"titleTemplate":6},"reloadNuxtApp","/docs/3.x/api/utils/reload-nuxt-app","docs/3.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":731,"stem":732,"titleTemplate":6},"setPageLayout","/docs/3.x/api/utils/set-page-layout","docs/3.x/4.api/3.utils/set-page-layout",{"title":734,"path":735,"stem":736,"titleTemplate":6},"setResponseStatus","/docs/3.x/api/utils/set-response-status","docs/3.x/4.api/3.utils/set-response-status",{"title":738,"path":739,"stem":740,"titleTemplate":6},"showError","/docs/3.x/api/utils/show-error","docs/3.x/4.api/3.utils/show-error",{"title":742,"path":743,"stem":744,"titleTemplate":6},"updateAppConfig","/docs/3.x/api/utils/update-app-config","docs/3.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":749,"stem":750,"children":751,"page":108},"Commands","%s · Nuxt Commands","i-lucide-square-terminal","/docs/3.x/api/commands","docs/3.x/4.api/4.commands",[752,756,760,764,768,772,776,780,784,788,792,796,800,804,808,812],{"title":753,"path":754,"stem":755,"titleTemplate":6},"nuxt add","/docs/3.x/api/commands/add","docs/3.x/4.api/4.commands/add",{"title":757,"path":758,"stem":759,"titleTemplate":6},"nuxt analyze","/docs/3.x/api/commands/analyze","docs/3.x/4.api/4.commands/analyze",{"title":761,"path":762,"stem":763,"titleTemplate":6},"nuxt build","/docs/3.x/api/commands/build","docs/3.x/4.api/4.commands/build",{"title":765,"path":766,"stem":767,"titleTemplate":6},"nuxt build-module","/docs/3.x/api/commands/build-module","docs/3.x/4.api/4.commands/build-module",{"title":769,"path":770,"stem":771,"titleTemplate":6},"nuxt cleanup","/docs/3.x/api/commands/cleanup","docs/3.x/4.api/4.commands/cleanup",{"title":773,"path":774,"stem":775,"titleTemplate":6},"nuxt dev","/docs/3.x/api/commands/dev","docs/3.x/4.api/4.commands/dev",{"title":777,"path":778,"stem":779,"titleTemplate":6},"nuxt devtools","/docs/3.x/api/commands/devtools","docs/3.x/4.api/4.commands/devtools",{"title":781,"path":782,"stem":783,"titleTemplate":6},"nuxt generate","/docs/3.x/api/commands/generate","docs/3.x/4.api/4.commands/generate",{"title":785,"path":786,"stem":787,"titleTemplate":6},"nuxt info","/docs/3.x/api/commands/info","docs/3.x/4.api/4.commands/info",{"title":789,"path":790,"stem":791,"titleTemplate":6},"create nuxt","/docs/3.x/api/commands/init","docs/3.x/4.api/4.commands/init",{"title":793,"path":794,"stem":795,"titleTemplate":6},"nuxt module","/docs/3.x/api/commands/module","docs/3.x/4.api/4.commands/module",{"title":797,"path":798,"stem":799,"titleTemplate":6},"nuxt prepare","/docs/3.x/api/commands/prepare","docs/3.x/4.api/4.commands/prepare",{"title":801,"path":802,"stem":803,"titleTemplate":6},"nuxt preview","/docs/3.x/api/commands/preview","docs/3.x/4.api/4.commands/preview",{"title":805,"path":806,"stem":807,"titleTemplate":6},"nuxt test","/docs/3.x/api/commands/test","docs/3.x/4.api/4.commands/test",{"title":809,"path":810,"stem":811,"titleTemplate":6},"nuxt typecheck","/docs/3.x/api/commands/typecheck","docs/3.x/4.api/4.commands/typecheck",{"title":813,"path":814,"stem":815,"titleTemplate":6},"nuxt upgrade","/docs/3.x/api/commands/upgrade","docs/3.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":819,"stem":820,"children":821,"page":108},"%s · Nuxt Kit","i-lucide-package","/docs/3.x/api/kit","docs/3.x/4.api/5.kit",[822,825,828,832,836,840,844,848,852,855,859,863,866,869,873,877,881,885],{"title":276,"path":823,"stem":824,"titleTemplate":6},"/docs/3.x/api/kit/modules","docs/3.x/4.api/5.kit/1.modules",{"title":399,"path":826,"stem":827,"titleTemplate":6},"/docs/3.x/api/kit/runtime-config","docs/3.x/4.api/5.kit/10.runtime-config",{"title":829,"path":830,"stem":831,"titleTemplate":6},"Templates","/docs/3.x/api/kit/templates","docs/3.x/4.api/5.kit/10.templates",{"title":833,"path":834,"stem":835,"titleTemplate":6},"Nitro","/docs/3.x/api/kit/nitro","docs/3.x/4.api/5.kit/11.nitro",{"title":837,"path":838,"stem":839,"titleTemplate":6},"Resolving","/docs/3.x/api/kit/resolving","docs/3.x/4.api/5.kit/12.resolving",{"title":841,"path":842,"stem":843,"titleTemplate":6},"Logging","/docs/3.x/api/kit/logging","docs/3.x/4.api/5.kit/13.logging",{"title":845,"path":846,"stem":847,"titleTemplate":6},"Builder","/docs/3.x/api/kit/builder","docs/3.x/4.api/5.kit/14.builder",{"title":849,"path":850,"stem":851,"titleTemplate":6},"Examples","/docs/3.x/api/kit/examples","docs/3.x/4.api/5.kit/15.examples",{"title":84,"path":853,"stem":854,"titleTemplate":6},"/docs/3.x/api/kit/layers","docs/3.x/4.api/5.kit/16.layers",{"title":856,"path":857,"stem":858,"titleTemplate":6},"Programmatic Usage","/docs/3.x/api/kit/programmatic","docs/3.x/4.api/5.kit/2.programmatic",{"title":860,"path":861,"stem":862,"titleTemplate":6},"Compatibility","/docs/3.x/api/kit/compatibility","docs/3.x/4.api/5.kit/3.compatibility",{"title":268,"path":864,"stem":865,"titleTemplate":6},"/docs/3.x/api/kit/autoimports","docs/3.x/4.api/5.kit/4.autoimports",{"title":434,"path":867,"stem":868,"titleTemplate":6},"/docs/3.x/api/kit/components","docs/3.x/4.api/5.kit/5.components",{"title":870,"path":871,"stem":872,"titleTemplate":6},"Context","/docs/3.x/api/kit/context","docs/3.x/4.api/5.kit/6.context",{"title":874,"path":875,"stem":876,"titleTemplate":6},"Pages","/docs/3.x/api/kit/pages","docs/3.x/4.api/5.kit/7.pages",{"title":878,"path":879,"stem":880,"titleTemplate":6},"Layout","/docs/3.x/api/kit/layout","docs/3.x/4.api/5.kit/8.layout",{"title":882,"path":883,"stem":884,"titleTemplate":6},"Head","/docs/3.x/api/kit/head","docs/3.x/4.api/5.kit/9.head",{"title":886,"path":887,"stem":888,"titleTemplate":6},"Plugins","/docs/3.x/api/kit/plugins","docs/3.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":892,"stem":893,"children":894,"page":108},"Advanced","i-lucide-brain","/docs/3.x/api/advanced","docs/3.x/4.api/6.advanced",[895,898],{"title":407,"path":896,"stem":897,"titleTemplate":6},"/docs/3.x/api/advanced/hooks","docs/3.x/4.api/6.advanced/1.hooks",{"title":899,"path":900,"stem":901,"titleTemplate":6},"Import meta","/docs/3.x/api/advanced/import-meta","docs/3.x/4.api/6.advanced/2.import-meta",{"title":903,"path":904,"stem":905,"titleTemplate":906,"icon":32},"Nuxt Configuration","/docs/3.x/api/nuxt-config","docs/3.x/4.api/6.nuxt-config","%s",{"title":849,"titleTemplate":908,"icon":909,"path":910,"stem":911,"children":912,"page":108},"%s · Nuxt Examples","i-lucide-app-window-mac","/docs/3.x/examples","docs/3.x/4.examples",[913,917,939,954,990],{"title":914,"path":915,"stem":916,"titleTemplate":6},"Hello World","/docs/3.x/examples/hello-world","docs/3.x/4.examples/0.hello-world",{"title":395,"path":918,"stem":919,"children":920,"page":108},"/docs/3.x/examples/features","docs/3.x/4.examples/1.features",[921,925,928,931,935],{"title":922,"path":923,"stem":924,"titleTemplate":6},"Auto Imports","/docs/3.x/examples/features/auto-imports","docs/3.x/4.examples/1.features/1.auto-imports",{"title":64,"path":926,"stem":927,"titleTemplate":6},"/docs/3.x/examples/features/data-fetching","docs/3.x/4.examples/1.features/2.data-fetching",{"title":69,"path":929,"stem":930,"titleTemplate":6},"/docs/3.x/examples/features/state-management","docs/3.x/4.examples/1.features/3.state-management",{"title":932,"path":933,"stem":934,"titleTemplate":6},"Meta Tags","/docs/3.x/examples/features/meta-tags","docs/3.x/4.examples/1.features/4.meta-tags",{"title":936,"path":937,"stem":938,"titleTemplate":6},"Layouts","/docs/3.x/examples/features/layouts","docs/3.x/4.examples/1.features/5.layouts",{"title":49,"path":940,"stem":941,"children":942,"page":108},"/docs/3.x/examples/routing","docs/3.x/4.examples/2.routing",[943,947,950],{"title":944,"path":945,"stem":946,"titleTemplate":6},"Middleware","/docs/3.x/examples/routing/middleware","docs/3.x/4.examples/2.routing/middleware",{"title":874,"path":948,"stem":949,"titleTemplate":6},"/docs/3.x/examples/routing/pages","docs/3.x/4.examples/2.routing/pages",{"title":951,"path":952,"stem":953,"titleTemplate":6},"Universal Router","/docs/3.x/examples/routing/universal-router","docs/3.x/4.examples/2.routing/universal-router",{"title":890,"path":955,"stem":956,"children":957,"page":108},"/docs/3.x/examples/advanced","docs/3.x/4.examples/4.advanced",[958,961,964,968,972,976,980,983,986],{"title":84,"path":959,"stem":960,"titleTemplate":6},"/docs/3.x/examples/advanced/config-extends","docs/3.x/4.examples/4.advanced/config-extends",{"title":74,"path":962,"stem":963,"titleTemplate":6},"/docs/3.x/examples/advanced/error-handling","docs/3.x/4.examples/4.advanced/error-handling",{"title":965,"path":966,"stem":967,"titleTemplate":6},"JSX / TSX","/docs/3.x/examples/advanced/jsx","docs/3.x/4.examples/4.advanced/jsx",{"title":969,"path":970,"stem":971,"titleTemplate":6},"Locale","/docs/3.x/examples/advanced/locale","docs/3.x/4.examples/4.advanced/locale",{"title":973,"path":974,"stem":975,"titleTemplate":6},"Module Extend Pages","/docs/3.x/examples/advanced/module-extend-pages","docs/3.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":978,"stem":979,"titleTemplate":6},"Teleport","/docs/3.x/examples/advanced/teleport","docs/3.x/4.examples/4.advanced/teleport",{"title":99,"path":981,"stem":982,"titleTemplate":6},"/docs/3.x/examples/advanced/testing","docs/3.x/4.examples/4.advanced/testing",{"title":519,"path":984,"stem":985,"titleTemplate":6},"/docs/3.x/examples/advanced/use-cookie","docs/3.x/4.examples/4.advanced/use-cookie",{"title":987,"path":988,"stem":989,"titleTemplate":6},"Use Custom Fetch Composable","/docs/3.x/examples/advanced/use-custom-fetch-composable","docs/3.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":992,"stem":993,"children":994,"page":108},"Experimental","/docs/3.x/examples/experimental","docs/3.x/4.examples/7.experimental",[995],{"title":996,"path":997,"stem":998,"titleTemplate":6},"WASM","/docs/3.x/examples/experimental/wasm","docs/3.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":1003,"stem":1004,"children":1005,"page":108},"Community","%s · Nuxt Community","i-lucide-messages-square","/docs/3.x/community","docs/3.x/5.community",[1006,1011,1016,1021,1026,1031],{"title":1007,"path":1008,"stem":1009,"titleTemplate":6,"icon":1010},"Getting Help","/docs/3.x/community/getting-help","docs/3.x/5.community/2.getting-help","i-lucide-life-buoy",{"title":1012,"path":1013,"stem":1014,"titleTemplate":6,"icon":1015},"Reporting Bugs","/docs/3.x/community/reporting-bugs","docs/3.x/5.community/3.reporting-bugs","i-lucide-bug",{"title":1017,"path":1018,"stem":1019,"titleTemplate":6,"icon":1020},"Contribution","/docs/3.x/community/contribution","docs/3.x/5.community/4.contribution","i-lucide-git-pull-request",{"title":1022,"path":1023,"stem":1024,"titleTemplate":6,"icon":1025},"Framework","/docs/3.x/community/framework-contribution","docs/3.x/5.community/5.framework-contribution","i-lucide-github",{"title":1027,"path":1028,"stem":1029,"titleTemplate":6,"icon":1030},"Roadmap","/docs/3.x/community/roadmap","docs/3.x/5.community/6.roadmap","i-lucide-map",{"title":1032,"path":1033,"stem":1034,"titleTemplate":6,"icon":1035},"Releases","/docs/3.x/community/changelog","docs/3.x/5.community/7.changelog","i-lucide-bell-dot",{"title":1037,"titleTemplate":1038,"icon":1039,"path":1040,"stem":1041,"children":1042,"page":108},"Migrate to Nuxt Bridge","Migrate to Nuxt Bridge: %s","i-lucide-ship","/docs/3.x/bridge","docs/3.x/6.bridge",[1043,1047,1050,1053,1057,1061,1065,1068,1071,1074],{"title":1044,"path":1045,"stem":1046,"titleTemplate":6},"Overview","/docs/3.x/bridge/overview","docs/3.x/6.bridge/1.overview",{"title":29,"path":1048,"stem":1049,"titleTemplate":6},"/docs/3.x/bridge/configuration","docs/3.x/6.bridge/10.configuration",{"title":280,"path":1051,"stem":1052,"titleTemplate":6},"/docs/3.x/bridge/typescript","docs/3.x/6.bridge/2.typescript",{"title":1054,"path":1055,"stem":1056,"titleTemplate":6},"Legacy Composition API","/docs/3.x/bridge/bridge-composition-api","docs/3.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":1059,"stem":1060,"titleTemplate":6},"Plugins and Middleware","/docs/3.x/bridge/plugins-and-middleware","docs/3.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":1063,"stem":1064,"titleTemplate":6},"New Composition API","/docs/3.x/bridge/nuxt3-compatible-api","docs/3.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":1066,"stem":1067,"titleTemplate":6},"/docs/3.x/bridge/meta","docs/3.x/6.bridge/6.meta",{"title":399,"path":1069,"stem":1070,"titleTemplate":6},"/docs/3.x/bridge/runtime-config","docs/3.x/6.bridge/7.runtime-config",{"title":833,"path":1072,"stem":1073,"titleTemplate":6},"/docs/3.x/bridge/nitro","docs/3.x/6.bridge/8.nitro",{"title":1075,"path":1076,"stem":1077,"titleTemplate":6},"Vite","/docs/3.x/bridge/vite","docs/3.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":1081,"stem":1082,"children":1083,"page":108},"Migrate to Nuxt 3","Migrate to Nuxt 3: %s","/docs/3.x/migration","docs/3.x/7.migration",[1084,1087,1091,1094,1097,1100,1103,1106,1109,1113,1117],{"title":1044,"path":1085,"stem":1086,"titleTemplate":6},"/docs/3.x/migration/overview","docs/3.x/7.migration/1.overview",{"title":1088,"path":1089,"stem":1090,"titleTemplate":6},"Build Tooling","/docs/3.x/migration/bundling","docs/3.x/7.migration/10.bundling",{"title":79,"path":1092,"stem":1093,"titleTemplate":6},"/docs/3.x/migration/server","docs/3.x/7.migration/11.server",{"title":29,"path":1095,"stem":1096,"titleTemplate":6},"/docs/3.x/migration/configuration","docs/3.x/7.migration/2.configuration",{"title":276,"path":1098,"stem":1099,"titleTemplate":6},"/docs/3.x/migration/module-authors","docs/3.x/7.migration/20.module-authors",{"title":922,"path":1101,"stem":1102,"titleTemplate":6},"/docs/3.x/migration/auto-imports","docs/3.x/7.migration/3.auto-imports",{"title":932,"path":1104,"stem":1105,"titleTemplate":6},"/docs/3.x/migration/meta","docs/3.x/7.migration/4.meta",{"title":1058,"path":1107,"stem":1108,"titleTemplate":6},"/docs/3.x/migration/plugins-and-middleware","docs/3.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":1111,"stem":1112,"titleTemplate":6},"Pages and Layouts","/docs/3.x/migration/pages-and-layouts","docs/3.x/7.migration/6.pages-and-layouts",{"title":1114,"path":1115,"stem":1116,"titleTemplate":6},"Component Options","/docs/3.x/migration/component-options","docs/3.x/7.migration/7.component-options",{"title":399,"path":1118,"stem":1119,"titleTemplate":6},"/docs/3.x/migration/runtime-config","docs/3.x/7.migration/8.runtime-config",{"title":5,"titleTemplate":6,"icon":7,"path":1121,"stem":1122,"children":1123,"page":108},"/docs/4.x","docs/4.x",[1124,1182,1276,1404,1770,1847,1869,1903],{"title":12,"titleTemplate":13,"icon":14,"path":1125,"stem":1126,"children":1127,"page":108},"/docs/4.x/getting-started","docs/4.x/1.getting-started",[1128,1131,1134,1137,1140,1143,1146,1149,1152,1155,1158,1161,1164,1167,1170,1173,1176,1179],{"title":19,"path":1129,"stem":1130,"titleTemplate":6,"icon":22},"/docs/4.x/getting-started/introduction","docs/4.x/1.getting-started/01.introduction",{"title":24,"path":1132,"stem":1133,"titleTemplate":6,"icon":27},"/docs/4.x/getting-started/installation","docs/4.x/1.getting-started/02.installation",{"title":29,"path":1135,"stem":1136,"titleTemplate":6,"icon":32},"/docs/4.x/getting-started/configuration","docs/4.x/1.getting-started/03.configuration",{"title":34,"path":1138,"stem":1139,"titleTemplate":6,"icon":37},"/docs/4.x/getting-started/views","docs/4.x/1.getting-started/04.views",{"title":39,"path":1141,"stem":1142,"titleTemplate":6,"icon":42},"/docs/4.x/getting-started/assets","docs/4.x/1.getting-started/05.assets",{"title":44,"path":1144,"stem":1145,"titleTemplate":6,"icon":47},"/docs/4.x/getting-started/styling","docs/4.x/1.getting-started/06.styling",{"title":49,"path":1147,"stem":1148,"titleTemplate":6,"icon":52},"/docs/4.x/getting-started/routing","docs/4.x/1.getting-started/07.routing",{"title":54,"path":1150,"stem":1151,"titleTemplate":6,"icon":57},"/docs/4.x/getting-started/seo-meta","docs/4.x/1.getting-started/08.seo-meta",{"title":59,"path":1153,"stem":1154,"titleTemplate":6,"icon":62},"/docs/4.x/getting-started/transitions","docs/4.x/1.getting-started/09.transitions",{"title":64,"path":1156,"stem":1157,"titleTemplate":6,"icon":67},"/docs/4.x/getting-started/data-fetching","docs/4.x/1.getting-started/10.data-fetching",{"title":69,"path":1159,"stem":1160,"titleTemplate":6,"icon":72},"/docs/4.x/getting-started/state-management","docs/4.x/1.getting-started/11.state-management",{"title":74,"path":1162,"stem":1163,"titleTemplate":6,"icon":77},"/docs/4.x/getting-started/error-handling","docs/4.x/1.getting-started/12.error-handling",{"title":79,"path":1165,"stem":1166,"titleTemplate":6,"icon":82},"/docs/4.x/getting-started/server","docs/4.x/1.getting-started/13.server",{"title":84,"path":1168,"stem":1169,"titleTemplate":6,"icon":87},"/docs/4.x/getting-started/layers","docs/4.x/1.getting-started/14.layers",{"title":89,"path":1171,"stem":1172,"titleTemplate":6,"icon":92},"/docs/4.x/getting-started/prerendering","docs/4.x/1.getting-started/15.prerendering",{"title":94,"path":1174,"stem":1175,"titleTemplate":6,"icon":97},"/docs/4.x/getting-started/deployment","docs/4.x/1.getting-started/16.deployment",{"title":99,"path":1177,"stem":1178,"titleTemplate":6,"icon":102},"/docs/4.x/getting-started/testing","docs/4.x/1.getting-started/17.testing",{"title":104,"path":1180,"stem":1181,"titleTemplate":6,"icon":107},"/docs/4.x/getting-started/upgrade","docs/4.x/1.getting-started/18.upgrade",{"title":110,"titleTemplate":111,"icon":112,"path":1183,"stem":1184,"children":1185,"page":108},"/docs/4.x/directory-structure","docs/4.x/2.directory-structure",[1186,1189,1192,1234,1237,1240,1243,1246,1249,1252,1255,1258,1261,1264,1267,1270,1273],{"title":117,"path":1187,"stem":1188,"titleTemplate":6,"icon":120},"/docs/4.x/directory-structure/nuxt","docs/4.x/2.directory-structure/0.nuxt",{"title":122,"path":1190,"stem":1191,"titleTemplate":6,"icon":125},"/docs/4.x/directory-structure/output","docs/4.x/2.directory-structure/0.output",{"title":1193,"titleTemplate":111,"head":1194,"defaultOpen":1196,"icon":1197,"path":1198,"stem":1199,"children":1200,"page":108},"app",{"title":1195},"app/",true,"i-vscode-icons-folder-type-app","/docs/4.x/directory-structure/app","docs/4.x/2.directory-structure/1.app",[1201,1204,1207,1210,1213,1216,1219,1222,1225,1228,1231],{"title":127,"path":1202,"stem":1203,"titleTemplate":6,"icon":130},"/docs/4.x/directory-structure/app/assets","docs/4.x/2.directory-structure/1.app/1.assets",{"title":132,"path":1205,"stem":1206,"titleTemplate":6,"icon":135},"/docs/4.x/directory-structure/app/components","docs/4.x/2.directory-structure/1.app/1.components",{"title":137,"path":1208,"stem":1209,"titleTemplate":6,"icon":140},"/docs/4.x/directory-structure/app/composables","docs/4.x/2.directory-structure/1.app/1.composables",{"title":152,"path":1211,"stem":1212,"titleTemplate":6,"icon":155},"/docs/4.x/directory-structure/app/layouts","docs/4.x/2.directory-structure/1.app/1.layouts",{"title":157,"path":1214,"stem":1215,"titleTemplate":6,"icon":160},"/docs/4.x/directory-structure/app/middleware","docs/4.x/2.directory-structure/1.app/1.middleware",{"title":171,"path":1217,"stem":1218,"titleTemplate":6,"icon":155},"/docs/4.x/directory-structure/app/pages","docs/4.x/2.directory-structure/1.app/1.pages",{"title":175,"path":1220,"stem":1221,"titleTemplate":6,"icon":178},"/docs/4.x/directory-structure/app/plugins","docs/4.x/2.directory-structure/1.app/1.plugins",{"title":195,"path":1223,"stem":1224,"titleTemplate":6,"icon":198},"/docs/4.x/directory-structure/app/utils","docs/4.x/2.directory-structure/1.app/1.utils",{"title":219,"path":1226,"stem":1227,"titleTemplate":6,"icon":222},"/docs/4.x/directory-structure/app/app","docs/4.x/2.directory-structure/1.app/3.app",{"title":224,"path":1229,"stem":1230,"titleTemplate":6,"icon":227},"/docs/4.x/directory-structure/app/app-config","docs/4.x/2.directory-structure/1.app/3.app-config",{"title":229,"path":1232,"stem":1233,"titleTemplate":6,"icon":222},"/docs/4.x/directory-structure/app/error","docs/4.x/2.directory-structure/1.app/3.error",{"title":142,"path":1235,"stem":1236,"titleTemplate":6,"icon":145},"/docs/4.x/directory-structure/content","docs/4.x/2.directory-structure/1.content",{"title":147,"path":1238,"stem":1239,"titleTemplate":6,"icon":150},"/docs/4.x/directory-structure/layers","docs/4.x/2.directory-structure/1.layers",{"title":162,"path":1241,"stem":1242,"titleTemplate":6,"icon":150},"/docs/4.x/directory-structure/modules","docs/4.x/2.directory-structure/1.modules",{"title":166,"path":1244,"stem":1245,"titleTemplate":6,"icon":169},"/docs/4.x/directory-structure/node_modules","docs/4.x/2.directory-structure/1.node_modules",{"title":180,"path":1247,"stem":1248,"titleTemplate":6,"icon":183},"/docs/4.x/directory-structure/public","docs/4.x/2.directory-structure/1.public",{"title":185,"path":1250,"stem":1251,"titleTemplate":6,"icon":188},"/docs/4.x/directory-structure/server","docs/4.x/2.directory-structure/1.server",{"title":190,"path":1253,"stem":1254,"titleTemplate":6,"icon":193},"/docs/4.x/directory-structure/shared","docs/4.x/2.directory-structure/1.shared",{"title":200,"path":1256,"stem":1257,"titleTemplate":6,"icon":203},"/docs/4.x/directory-structure/env","docs/4.x/2.directory-structure/2.env",{"title":205,"path":1259,"stem":1260,"titleTemplate":6,"icon":208},"/docs/4.x/directory-structure/gitignore","docs/4.x/2.directory-structure/2.gitignore",{"title":210,"path":1262,"stem":1263,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxtignore","docs/4.x/2.directory-structure/2.nuxtignore",{"title":215,"path":1265,"stem":1266,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxtrc","docs/4.x/2.directory-structure/2.nuxtrc",{"title":233,"path":1268,"stem":1269,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxt-config","docs/4.x/2.directory-structure/3.nuxt-config",{"title":237,"path":1271,"stem":1272,"titleTemplate":6,"icon":240},"/docs/4.x/directory-structure/package","docs/4.x/2.directory-structure/3.package",{"title":242,"path":1274,"stem":1275,"titleTemplate":6,"icon":245},"/docs/4.x/directory-structure/tsconfig","docs/4.x/2.directory-structure/3.tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":1277,"stem":1278,"children":1279,"page":108},"/docs/4.x/guide","docs/4.x/3.guide",[1280,1305,1319,1329,1354,1370],{"title":253,"titleTemplate":254,"icon":255,"path":1281,"stem":1282,"children":1283,"page":108},"/docs/4.x/guide/concepts","docs/4.x/3.guide/1.concepts",[1284,1287,1290,1293,1296,1299,1302],{"title":260,"path":1285,"stem":1286,"titleTemplate":6},"/docs/4.x/guide/concepts/rendering","docs/4.x/3.guide/1.concepts/1.rendering",{"title":264,"path":1288,"stem":1289,"titleTemplate":6},"/docs/4.x/guide/concepts/nuxt-lifecycle","docs/4.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":1291,"stem":1292,"titleTemplate":6},"/docs/4.x/guide/concepts/auto-imports","docs/4.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":1294,"stem":1295,"titleTemplate":6},"/docs/4.x/guide/concepts/server-engine","docs/4.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":1297,"stem":1298,"titleTemplate":6},"/docs/4.x/guide/concepts/modules","docs/4.x/3.guide/1.concepts/5.modules",{"title":280,"path":1300,"stem":1301,"titleTemplate":6},"/docs/4.x/guide/concepts/typescript","docs/4.x/3.guide/1.concepts/8.typescript",{"title":284,"path":1303,"stem":1304,"titleTemplate":6},"/docs/4.x/guide/concepts/code-style","docs/4.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":1306,"stem":1307,"children":1308,"page":108},"/docs/4.x/guide/best-practices","docs/4.x/3.guide/2.best-practices",[1309,1313,1316],{"title":1310,"path":1311,"stem":1312,"titleTemplate":6},"Nuxt and Hydration","/docs/4.x/guide/best-practices/hydration","docs/4.x/3.guide/2.best-practices/hydration",{"title":299,"path":1314,"stem":1315,"titleTemplate":6},"/docs/4.x/guide/best-practices/performance","docs/4.x/3.guide/2.best-practices/performance",{"title":303,"path":1317,"stem":1318,"titleTemplate":6},"/docs/4.x/guide/best-practices/plugins","docs/4.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":1320,"stem":1321,"children":1322,"page":108},"/docs/4.x/guide/ai","docs/4.x/3.guide/3.ai",[1323,1326],{"title":314,"path":1324,"stem":1325,"titleTemplate":6},"/docs/4.x/guide/ai/mcp","docs/4.x/3.guide/3.ai/1.mcp",{"title":318,"path":1327,"stem":1328,"titleTemplate":6},"/docs/4.x/guide/ai/llms-txt","docs/4.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":1330,"stem":1331,"children":1332,"page":108},"/docs/4.x/guide/modules","docs/4.x/3.guide/4.modules",[1333,1336,1339,1342,1345,1348,1351],{"title":329,"path":1334,"stem":1335,"titleTemplate":6},"/docs/4.x/guide/modules/getting-started","docs/4.x/3.guide/4.modules/1.getting-started",{"title":333,"path":1337,"stem":1338,"titleTemplate":6},"/docs/4.x/guide/modules/module-anatomy","docs/4.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":1340,"stem":1341,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-basics","docs/4.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":1343,"stem":1344,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-advanced","docs/4.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":1346,"stem":1347,"titleTemplate":6},"/docs/4.x/guide/modules/testing","docs/4.x/3.guide/4.modules/5.testing",{"title":349,"path":1349,"stem":1350,"titleTemplate":6},"/docs/4.x/guide/modules/best-practices","docs/4.x/3.guide/4.modules/6.best-practices",{"title":353,"path":1352,"stem":1353,"titleTemplate":6},"/docs/4.x/guide/modules/ecosystem","docs/4.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":1355,"stem":1356,"children":1357,"page":108},"/docs/4.x/guide/recipes","docs/4.x/3.guide/5.recipes",[1358,1361,1364,1367],{"title":364,"path":1359,"stem":1360,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-routing","docs/4.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":1362,"stem":1363,"titleTemplate":6},"/docs/4.x/guide/recipes/vite-plugin","docs/4.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":1365,"stem":1366,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-usefetch","docs/4.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":1368,"stem":1369,"titleTemplate":6},"/docs/4.x/guide/recipes/sessions-and-authentication","docs/4.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":1371,"stem":1372,"children":1373,"page":108},"/docs/4.x/guide/going-further","docs/4.x/3.guide/6.going-further",[1374,1377,1380,1383,1386,1389,1392,1395,1398,1401],{"title":387,"path":1375,"stem":1376,"titleTemplate":6},"/docs/4.x/guide/going-further/events","docs/4.x/3.guide/6.going-further/1.events",{"title":391,"path":1378,"stem":1379,"titleTemplate":6},"/docs/4.x/guide/going-further/experimental-features","docs/4.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":1381,"stem":1382,"titleTemplate":6},"/docs/4.x/guide/going-further/features","docs/4.x/3.guide/6.going-further/1.features",{"title":399,"path":1384,"stem":1385,"titleTemplate":6},"/docs/4.x/guide/going-further/runtime-config","docs/4.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":1387,"stem":1388,"titleTemplate":6},"/docs/4.x/guide/going-further/nightly-release-channel","docs/4.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":1390,"stem":1391,"titleTemplate":6},"/docs/4.x/guide/going-further/hooks","docs/4.x/3.guide/6.going-further/2.hooks",{"title":411,"path":1393,"stem":1394,"titleTemplate":6},"/docs/4.x/guide/going-further/kit","docs/4.x/3.guide/6.going-further/4.kit",{"title":415,"path":1396,"stem":1397,"titleTemplate":6},"/docs/4.x/guide/going-further/nuxt-app","docs/4.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":1399,"stem":1400,"titleTemplate":6},"/docs/4.x/guide/going-further/layers","docs/4.x/3.guide/6.going-further/7.layers",{"title":423,"path":1402,"stem":1403,"titleTemplate":6},"/docs/4.x/guide/going-further/debugging","docs/4.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":1405,"stem":1406,"children":1407,"page":108},"/docs/4.x/api","docs/4.x/4.api",[1408,1461,1556,1647,1699,1757,1767],{"title":434,"titleTemplate":435,"icon":324,"path":1409,"stem":1410,"children":1411,"page":108},"/docs/4.x/api/components","docs/4.x/4.api/1.components",[1412,1415,1418,1421,1424,1427,1430,1433,1437,1440,1443,1446,1449,1452,1455,1458],{"title":440,"path":1413,"stem":1414,"titleTemplate":6},"/docs/4.x/api/components/client-only","docs/4.x/4.api/1.components/1.client-only",{"title":444,"path":1416,"stem":1417,"titleTemplate":6},"/docs/4.x/api/components/dev-only","docs/4.x/4.api/1.components/1.dev-only",{"title":448,"path":1419,"stem":1420,"titleTemplate":6},"/docs/4.x/api/components/nuxt-client-fallback","docs/4.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":1422,"stem":1423,"titleTemplate":6},"/docs/4.x/api/components/nuxt-picture","docs/4.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":1425,"stem":1426,"titleTemplate":6},"/docs/4.x/api/components/teleports","docs/4.x/4.api/1.components/11.teleports",{"title":460,"path":1428,"stem":1429,"titleTemplate":6},"/docs/4.x/api/components/nuxt-route-announcer","docs/4.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":1431,"stem":1432,"titleTemplate":6},"/docs/4.x/api/components/nuxt-time","docs/4.x/4.api/1.components/13.nuxt-time",{"title":1434,"path":1435,"stem":1436,"titleTemplate":6},"\u003CNuxtAnnouncer>","/docs/4.x/api/components/nuxt-announcer","docs/4.x/4.api/1.components/14.nuxt-announcer",{"title":468,"path":1438,"stem":1439,"titleTemplate":6},"/docs/4.x/api/components/nuxt-page","docs/4.x/4.api/1.components/2.nuxt-page",{"title":472,"path":1441,"stem":1442,"titleTemplate":6},"/docs/4.x/api/components/nuxt-layout","docs/4.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":1444,"stem":1445,"titleTemplate":6},"/docs/4.x/api/components/nuxt-link","docs/4.x/4.api/1.components/4.nuxt-link",{"title":480,"path":1447,"stem":1448,"titleTemplate":6},"/docs/4.x/api/components/nuxt-loading-indicator","docs/4.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":1450,"stem":1451,"titleTemplate":6},"/docs/4.x/api/components/nuxt-error-boundary","docs/4.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":1453,"stem":1454,"titleTemplate":6},"/docs/4.x/api/components/nuxt-welcome","docs/4.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":1456,"stem":1457,"titleTemplate":6},"/docs/4.x/api/components/nuxt-island","docs/4.x/4.api/1.components/8.nuxt-island",{"title":496,"path":1459,"stem":1460,"titleTemplate":6},"/docs/4.x/api/components/nuxt-img","docs/4.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":1462,"stem":1463,"children":1464,"page":108},"/docs/4.x/api/composables","docs/4.x/4.api/2.composables",[1465,1468,1472,1475,1478,1481,1484,1487,1490,1493,1496,1499,1502,1505,1508,1511,1514,1517,1520,1523,1526,1529,1532,1535,1538,1541,1544,1547,1550,1553],{"title":507,"path":1466,"stem":1467,"titleTemplate":6},"/docs/4.x/api/composables/on-prehydrate","docs/4.x/4.api/2.composables/on-prehydrate",{"title":1469,"path":1470,"stem":1471,"titleTemplate":6},"useAnnouncer","/docs/4.x/api/composables/use-announcer","docs/4.x/4.api/2.composables/use-announcer",{"title":511,"path":1473,"stem":1474,"titleTemplate":6},"/docs/4.x/api/composables/use-app-config","docs/4.x/4.api/2.composables/use-app-config",{"title":515,"path":1476,"stem":1477,"titleTemplate":6},"/docs/4.x/api/composables/use-async-data","docs/4.x/4.api/2.composables/use-async-data",{"title":519,"path":1479,"stem":1480,"titleTemplate":6},"/docs/4.x/api/composables/use-cookie","docs/4.x/4.api/2.composables/use-cookie",{"title":523,"path":1482,"stem":1483,"titleTemplate":6},"/docs/4.x/api/composables/use-error","docs/4.x/4.api/2.composables/use-error",{"title":527,"path":1485,"stem":1486,"titleTemplate":6},"/docs/4.x/api/composables/use-fetch","docs/4.x/4.api/2.composables/use-fetch",{"title":531,"path":1488,"stem":1489,"titleTemplate":6},"/docs/4.x/api/composables/use-head","docs/4.x/4.api/2.composables/use-head",{"title":535,"path":1491,"stem":1492,"titleTemplate":6},"/docs/4.x/api/composables/use-head-safe","docs/4.x/4.api/2.composables/use-head-safe",{"title":539,"path":1494,"stem":1495,"titleTemplate":6},"/docs/4.x/api/composables/use-hydration","docs/4.x/4.api/2.composables/use-hydration",{"title":543,"path":1497,"stem":1498,"titleTemplate":6},"/docs/4.x/api/composables/use-lazy-async-data","docs/4.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":1500,"stem":1501,"titleTemplate":6},"/docs/4.x/api/composables/use-lazy-fetch","docs/4.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":1503,"stem":1504,"titleTemplate":6},"/docs/4.x/api/composables/use-loading-indicator","docs/4.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":1506,"stem":1507,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-app","docs/4.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":1509,"stem":1510,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-data","docs/4.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":1512,"stem":1513,"titleTemplate":6},"/docs/4.x/api/composables/use-preview-mode","docs/4.x/4.api/2.composables/use-preview-mode",{"title":567,"path":1515,"stem":1516,"titleTemplate":6},"/docs/4.x/api/composables/use-request-event","docs/4.x/4.api/2.composables/use-request-event",{"title":571,"path":1518,"stem":1519,"titleTemplate":6},"/docs/4.x/api/composables/use-request-fetch","docs/4.x/4.api/2.composables/use-request-fetch",{"title":575,"path":1521,"stem":1522,"titleTemplate":6},"/docs/4.x/api/composables/use-request-header","docs/4.x/4.api/2.composables/use-request-header",{"title":579,"path":1524,"stem":1525,"titleTemplate":6},"/docs/4.x/api/composables/use-request-headers","docs/4.x/4.api/2.composables/use-request-headers",{"title":583,"path":1527,"stem":1528,"titleTemplate":6},"/docs/4.x/api/composables/use-request-url","docs/4.x/4.api/2.composables/use-request-url",{"title":587,"path":1530,"stem":1531,"titleTemplate":6},"/docs/4.x/api/composables/use-response-header","docs/4.x/4.api/2.composables/use-response-header",{"title":591,"path":1533,"stem":1534,"titleTemplate":6},"/docs/4.x/api/composables/use-route","docs/4.x/4.api/2.composables/use-route",{"title":595,"path":1536,"stem":1537,"titleTemplate":6},"/docs/4.x/api/composables/use-route-announcer","docs/4.x/4.api/2.composables/use-route-announcer",{"title":599,"path":1539,"stem":1540,"titleTemplate":6},"/docs/4.x/api/composables/use-router","docs/4.x/4.api/2.composables/use-router",{"title":603,"path":1542,"stem":1543,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-config","docs/4.x/4.api/2.composables/use-runtime-config",{"title":607,"path":1545,"stem":1546,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-hook","docs/4.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":1548,"stem":1549,"titleTemplate":6},"/docs/4.x/api/composables/use-seo-meta","docs/4.x/4.api/2.composables/use-seo-meta",{"title":615,"path":1551,"stem":1552,"titleTemplate":6},"/docs/4.x/api/composables/use-server-seo-meta","docs/4.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":1554,"stem":1555,"titleTemplate":6},"/docs/4.x/api/composables/use-state","docs/4.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":1557,"stem":1558,"children":1559,"page":108},"/docs/4.x/api/utils","docs/4.x/4.api/3.utils",[1560,1563,1566,1569,1572,1575,1578,1581,1584,1587,1590,1593,1596,1599,1602,1605,1608,1611,1614,1617,1620,1623,1626,1629,1632,1635,1638,1641,1644],{"title":630,"path":1561,"stem":1562,"titleTemplate":6},"/docs/4.x/api/utils/dollarfetch","docs/4.x/4.api/3.utils/$fetch",{"title":634,"path":1564,"stem":1565,"titleTemplate":6},"/docs/4.x/api/utils/abort-navigation","docs/4.x/4.api/3.utils/abort-navigation",{"title":638,"path":1567,"stem":1568,"titleTemplate":6},"/docs/4.x/api/utils/add-route-middleware","docs/4.x/4.api/3.utils/add-route-middleware",{"title":642,"path":1570,"stem":1571,"titleTemplate":6},"/docs/4.x/api/utils/call-once","docs/4.x/4.api/3.utils/call-once",{"title":646,"path":1573,"stem":1574,"titleTemplate":6},"/docs/4.x/api/utils/clear-error","docs/4.x/4.api/3.utils/clear-error",{"title":650,"path":1576,"stem":1577,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-data","docs/4.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":1579,"stem":1580,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-state","docs/4.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":1582,"stem":1583,"titleTemplate":6},"/docs/4.x/api/utils/create-error","docs/4.x/4.api/3.utils/create-error",{"title":662,"path":1585,"stem":1586,"titleTemplate":6},"/docs/4.x/api/utils/define-lazy-hydration-component","docs/4.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":1588,"stem":1589,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-component","docs/4.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":1591,"stem":1592,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-plugin","docs/4.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":1594,"stem":1595,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-route-middleware","docs/4.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":1597,"stem":1598,"titleTemplate":6},"/docs/4.x/api/utils/define-page-meta","docs/4.x/4.api/3.utils/define-page-meta",{"title":682,"path":1600,"stem":1601,"titleTemplate":6},"/docs/4.x/api/utils/define-route-rules","docs/4.x/4.api/3.utils/define-route-rules",{"title":686,"path":1603,"stem":1604,"titleTemplate":6},"/docs/4.x/api/utils/navigate-to","docs/4.x/4.api/3.utils/navigate-to",{"title":690,"path":1606,"stem":1607,"titleTemplate":6},"/docs/4.x/api/utils/on-before-route-leave","docs/4.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":1609,"stem":1610,"titleTemplate":6},"/docs/4.x/api/utils/on-before-route-update","docs/4.x/4.api/3.utils/on-before-route-update",{"title":698,"path":1612,"stem":1613,"titleTemplate":6},"/docs/4.x/api/utils/on-nuxt-ready","docs/4.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":1615,"stem":1616,"titleTemplate":6},"/docs/4.x/api/utils/prefetch-components","docs/4.x/4.api/3.utils/prefetch-components",{"title":706,"path":1618,"stem":1619,"titleTemplate":6},"/docs/4.x/api/utils/preload-components","docs/4.x/4.api/3.utils/preload-components",{"title":710,"path":1621,"stem":1622,"titleTemplate":6},"/docs/4.x/api/utils/preload-route-components","docs/4.x/4.api/3.utils/preload-route-components",{"title":714,"path":1624,"stem":1625,"titleTemplate":6},"/docs/4.x/api/utils/prerender-routes","docs/4.x/4.api/3.utils/prerender-routes",{"title":718,"path":1627,"stem":1628,"titleTemplate":6},"/docs/4.x/api/utils/refresh-cookie","docs/4.x/4.api/3.utils/refresh-cookie",{"title":722,"path":1630,"stem":1631,"titleTemplate":6},"/docs/4.x/api/utils/refresh-nuxt-data","docs/4.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":1633,"stem":1634,"titleTemplate":6},"/docs/4.x/api/utils/reload-nuxt-app","docs/4.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":1636,"stem":1637,"titleTemplate":6},"/docs/4.x/api/utils/set-page-layout","docs/4.x/4.api/3.utils/set-page-layout",{"title":734,"path":1639,"stem":1640,"titleTemplate":6},"/docs/4.x/api/utils/set-response-status","docs/4.x/4.api/3.utils/set-response-status",{"title":738,"path":1642,"stem":1643,"titleTemplate":6},"/docs/4.x/api/utils/show-error","docs/4.x/4.api/3.utils/show-error",{"title":742,"path":1645,"stem":1646,"titleTemplate":6},"/docs/4.x/api/utils/update-app-config","docs/4.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":1648,"stem":1649,"children":1650,"page":108},"/docs/4.x/api/commands","docs/4.x/4.api/4.commands",[1651,1654,1657,1660,1663,1666,1669,1672,1675,1678,1681,1684,1687,1690,1693,1696],{"title":753,"path":1652,"stem":1653,"titleTemplate":6},"/docs/4.x/api/commands/add","docs/4.x/4.api/4.commands/add",{"title":757,"path":1655,"stem":1656,"titleTemplate":6},"/docs/4.x/api/commands/analyze","docs/4.x/4.api/4.commands/analyze",{"title":761,"path":1658,"stem":1659,"titleTemplate":6},"/docs/4.x/api/commands/build","docs/4.x/4.api/4.commands/build",{"title":765,"path":1661,"stem":1662,"titleTemplate":6},"/docs/4.x/api/commands/build-module","docs/4.x/4.api/4.commands/build-module",{"title":769,"path":1664,"stem":1665,"titleTemplate":6},"/docs/4.x/api/commands/cleanup","docs/4.x/4.api/4.commands/cleanup",{"title":773,"path":1667,"stem":1668,"titleTemplate":6},"/docs/4.x/api/commands/dev","docs/4.x/4.api/4.commands/dev",{"title":777,"path":1670,"stem":1671,"titleTemplate":6},"/docs/4.x/api/commands/devtools","docs/4.x/4.api/4.commands/devtools",{"title":781,"path":1673,"stem":1674,"titleTemplate":6},"/docs/4.x/api/commands/generate","docs/4.x/4.api/4.commands/generate",{"title":785,"path":1676,"stem":1677,"titleTemplate":6},"/docs/4.x/api/commands/info","docs/4.x/4.api/4.commands/info",{"title":789,"path":1679,"stem":1680,"titleTemplate":6},"/docs/4.x/api/commands/init","docs/4.x/4.api/4.commands/init",{"title":793,"path":1682,"stem":1683,"titleTemplate":6},"/docs/4.x/api/commands/module","docs/4.x/4.api/4.commands/module",{"title":797,"path":1685,"stem":1686,"titleTemplate":6},"/docs/4.x/api/commands/prepare","docs/4.x/4.api/4.commands/prepare",{"title":801,"path":1688,"stem":1689,"titleTemplate":6},"/docs/4.x/api/commands/preview","docs/4.x/4.api/4.commands/preview",{"title":805,"path":1691,"stem":1692,"titleTemplate":6},"/docs/4.x/api/commands/test","docs/4.x/4.api/4.commands/test",{"title":809,"path":1694,"stem":1695,"titleTemplate":6},"/docs/4.x/api/commands/typecheck","docs/4.x/4.api/4.commands/typecheck",{"title":813,"path":1697,"stem":1698,"titleTemplate":6},"/docs/4.x/api/commands/upgrade","docs/4.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":1700,"stem":1701,"children":1702,"page":108},"/docs/4.x/api/kit","docs/4.x/4.api/5.kit",[1703,1706,1709,1712,1715,1718,1721,1724,1727,1730,1733,1736,1739,1742,1745,1748,1751,1754],{"title":276,"path":1704,"stem":1705,"titleTemplate":6},"/docs/4.x/api/kit/modules","docs/4.x/4.api/5.kit/1.modules",{"title":399,"path":1707,"stem":1708,"titleTemplate":6},"/docs/4.x/api/kit/runtime-config","docs/4.x/4.api/5.kit/10.runtime-config",{"title":829,"path":1710,"stem":1711,"titleTemplate":6},"/docs/4.x/api/kit/templates","docs/4.x/4.api/5.kit/10.templates",{"title":833,"path":1713,"stem":1714,"titleTemplate":6},"/docs/4.x/api/kit/nitro","docs/4.x/4.api/5.kit/11.nitro",{"title":837,"path":1716,"stem":1717,"titleTemplate":6},"/docs/4.x/api/kit/resolving","docs/4.x/4.api/5.kit/12.resolving",{"title":841,"path":1719,"stem":1720,"titleTemplate":6},"/docs/4.x/api/kit/logging","docs/4.x/4.api/5.kit/13.logging",{"title":845,"path":1722,"stem":1723,"titleTemplate":6},"/docs/4.x/api/kit/builder","docs/4.x/4.api/5.kit/14.builder",{"title":849,"path":1725,"stem":1726,"titleTemplate":6},"/docs/4.x/api/kit/examples","docs/4.x/4.api/5.kit/15.examples",{"title":84,"path":1728,"stem":1729,"titleTemplate":6},"/docs/4.x/api/kit/layers","docs/4.x/4.api/5.kit/16.layers",{"title":856,"path":1731,"stem":1732,"titleTemplate":6},"/docs/4.x/api/kit/programmatic","docs/4.x/4.api/5.kit/2.programmatic",{"title":860,"path":1734,"stem":1735,"titleTemplate":6},"/docs/4.x/api/kit/compatibility","docs/4.x/4.api/5.kit/3.compatibility",{"title":268,"path":1737,"stem":1738,"titleTemplate":6},"/docs/4.x/api/kit/autoimports","docs/4.x/4.api/5.kit/4.autoimports",{"title":434,"path":1740,"stem":1741,"titleTemplate":6},"/docs/4.x/api/kit/components","docs/4.x/4.api/5.kit/5.components",{"title":870,"path":1743,"stem":1744,"titleTemplate":6},"/docs/4.x/api/kit/context","docs/4.x/4.api/5.kit/6.context",{"title":874,"path":1746,"stem":1747,"titleTemplate":6},"/docs/4.x/api/kit/pages","docs/4.x/4.api/5.kit/7.pages",{"title":878,"path":1749,"stem":1750,"titleTemplate":6},"/docs/4.x/api/kit/layout","docs/4.x/4.api/5.kit/8.layout",{"title":882,"path":1752,"stem":1753,"titleTemplate":6},"/docs/4.x/api/kit/head","docs/4.x/4.api/5.kit/9.head",{"title":886,"path":1755,"stem":1756,"titleTemplate":6},"/docs/4.x/api/kit/plugins","docs/4.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":1758,"stem":1759,"children":1760,"page":108},"/docs/4.x/api/advanced","docs/4.x/4.api/6.advanced",[1761,1764],{"title":407,"path":1762,"stem":1763,"titleTemplate":6},"/docs/4.x/api/advanced/hooks","docs/4.x/4.api/6.advanced/1.hooks",{"title":899,"path":1765,"stem":1766,"titleTemplate":6},"/docs/4.x/api/advanced/import-meta","docs/4.x/4.api/6.advanced/2.import-meta",{"title":903,"path":1768,"stem":1769,"titleTemplate":906,"icon":32},"/docs/4.x/api/nuxt-config","docs/4.x/4.api/6.nuxt-config",{"title":849,"titleTemplate":908,"icon":909,"path":1771,"stem":1772,"children":1773,"page":108},"/docs/4.x/examples","docs/4.x/4.examples",[1774,1777,1796,1809,1840],{"title":914,"path":1775,"stem":1776,"titleTemplate":6},"/docs/4.x/examples/hello-world","docs/4.x/4.examples/0.hello-world",{"title":395,"path":1778,"stem":1779,"children":1780,"page":108},"/docs/4.x/examples/features","docs/4.x/4.examples/1.features",[1781,1784,1787,1790,1793],{"title":922,"path":1782,"stem":1783,"titleTemplate":6},"/docs/4.x/examples/features/auto-imports","docs/4.x/4.examples/1.features/1.auto-imports",{"title":64,"path":1785,"stem":1786,"titleTemplate":6},"/docs/4.x/examples/features/data-fetching","docs/4.x/4.examples/1.features/2.data-fetching",{"title":69,"path":1788,"stem":1789,"titleTemplate":6},"/docs/4.x/examples/features/state-management","docs/4.x/4.examples/1.features/3.state-management",{"title":932,"path":1791,"stem":1792,"titleTemplate":6},"/docs/4.x/examples/features/meta-tags","docs/4.x/4.examples/1.features/4.meta-tags",{"title":936,"path":1794,"stem":1795,"titleTemplate":6},"/docs/4.x/examples/features/layouts","docs/4.x/4.examples/1.features/5.layouts",{"title":49,"path":1797,"stem":1798,"children":1799,"page":108},"/docs/4.x/examples/routing","docs/4.x/4.examples/2.routing",[1800,1803,1806],{"title":944,"path":1801,"stem":1802,"titleTemplate":6},"/docs/4.x/examples/routing/middleware","docs/4.x/4.examples/2.routing/middleware",{"title":874,"path":1804,"stem":1805,"titleTemplate":6},"/docs/4.x/examples/routing/pages","docs/4.x/4.examples/2.routing/pages",{"title":951,"path":1807,"stem":1808,"titleTemplate":6},"/docs/4.x/examples/routing/universal-router","docs/4.x/4.examples/2.routing/universal-router",{"title":890,"path":1810,"stem":1811,"children":1812,"page":108},"/docs/4.x/examples/advanced","docs/4.x/4.examples/4.advanced",[1813,1816,1819,1822,1825,1828,1831,1834,1837],{"title":84,"path":1814,"stem":1815,"titleTemplate":6},"/docs/4.x/examples/advanced/config-extends","docs/4.x/4.examples/4.advanced/config-extends",{"title":74,"path":1817,"stem":1818,"titleTemplate":6},"/docs/4.x/examples/advanced/error-handling","docs/4.x/4.examples/4.advanced/error-handling",{"title":965,"path":1820,"stem":1821,"titleTemplate":6},"/docs/4.x/examples/advanced/jsx","docs/4.x/4.examples/4.advanced/jsx",{"title":969,"path":1823,"stem":1824,"titleTemplate":6},"/docs/4.x/examples/advanced/locale","docs/4.x/4.examples/4.advanced/locale",{"title":973,"path":1826,"stem":1827,"titleTemplate":6},"/docs/4.x/examples/advanced/module-extend-pages","docs/4.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":1829,"stem":1830,"titleTemplate":6},"/docs/4.x/examples/advanced/teleport","docs/4.x/4.examples/4.advanced/teleport",{"title":99,"path":1832,"stem":1833,"titleTemplate":6},"/docs/4.x/examples/advanced/testing","docs/4.x/4.examples/4.advanced/testing",{"title":519,"path":1835,"stem":1836,"titleTemplate":6},"/docs/4.x/examples/advanced/use-cookie","docs/4.x/4.examples/4.advanced/use-cookie",{"title":987,"path":1838,"stem":1839,"titleTemplate":6},"/docs/4.x/examples/advanced/use-custom-fetch-composable","docs/4.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":1841,"stem":1842,"children":1843,"page":108},"/docs/4.x/examples/experimental","docs/4.x/4.examples/7.experimental",[1844],{"title":996,"path":1845,"stem":1846,"titleTemplate":6},"/docs/4.x/examples/experimental/wasm","docs/4.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":1848,"stem":1849,"children":1850,"page":108},"/docs/4.x/community","docs/4.x/5.community",[1851,1854,1857,1860,1863,1866],{"title":1007,"path":1852,"stem":1853,"titleTemplate":6,"icon":1010},"/docs/4.x/community/getting-help","docs/4.x/5.community/2.getting-help",{"title":1012,"path":1855,"stem":1856,"titleTemplate":6,"icon":1015},"/docs/4.x/community/reporting-bugs","docs/4.x/5.community/3.reporting-bugs",{"title":1017,"path":1858,"stem":1859,"titleTemplate":6,"icon":1020},"/docs/4.x/community/contribution","docs/4.x/5.community/4.contribution",{"title":1022,"path":1861,"stem":1862,"titleTemplate":6,"icon":1025},"/docs/4.x/community/framework-contribution","docs/4.x/5.community/5.framework-contribution",{"title":1027,"path":1864,"stem":1865,"titleTemplate":6,"icon":1030},"/docs/4.x/community/roadmap","docs/4.x/5.community/6.roadmap",{"title":1032,"path":1867,"stem":1868,"titleTemplate":6,"icon":1035},"/docs/4.x/community/changelog","docs/4.x/5.community/7.changelog",{"title":1037,"titleTemplate":1038,"icon":1039,"path":1870,"stem":1871,"children":1872,"page":108},"/docs/4.x/bridge","docs/4.x/6.bridge",[1873,1876,1879,1882,1885,1888,1891,1894,1897,1900],{"title":1044,"path":1874,"stem":1875,"titleTemplate":6},"/docs/4.x/bridge/overview","docs/4.x/6.bridge/1.overview",{"title":29,"path":1877,"stem":1878,"titleTemplate":6},"/docs/4.x/bridge/configuration","docs/4.x/6.bridge/10.configuration",{"title":280,"path":1880,"stem":1881,"titleTemplate":6},"/docs/4.x/bridge/typescript","docs/4.x/6.bridge/2.typescript",{"title":1054,"path":1883,"stem":1884,"titleTemplate":6},"/docs/4.x/bridge/bridge-composition-api","docs/4.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":1886,"stem":1887,"titleTemplate":6},"/docs/4.x/bridge/plugins-and-middleware","docs/4.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":1889,"stem":1890,"titleTemplate":6},"/docs/4.x/bridge/nuxt3-compatible-api","docs/4.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":1892,"stem":1893,"titleTemplate":6},"/docs/4.x/bridge/meta","docs/4.x/6.bridge/6.meta",{"title":399,"path":1895,"stem":1896,"titleTemplate":6},"/docs/4.x/bridge/runtime-config","docs/4.x/6.bridge/7.runtime-config",{"title":833,"path":1898,"stem":1899,"titleTemplate":6},"/docs/4.x/bridge/nitro","docs/4.x/6.bridge/8.nitro",{"title":1075,"path":1901,"stem":1902,"titleTemplate":6},"/docs/4.x/bridge/vite","docs/4.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":1904,"stem":1905,"children":1906,"page":108},"/docs/4.x/migration","docs/4.x/7.migration",[1907,1910,1913,1916,1919,1922,1925,1928,1931,1934,1937],{"title":1044,"path":1908,"stem":1909,"titleTemplate":6},"/docs/4.x/migration/overview","docs/4.x/7.migration/1.overview",{"title":1088,"path":1911,"stem":1912,"titleTemplate":6},"/docs/4.x/migration/bundling","docs/4.x/7.migration/10.bundling",{"title":79,"path":1914,"stem":1915,"titleTemplate":6},"/docs/4.x/migration/server","docs/4.x/7.migration/11.server",{"title":29,"path":1917,"stem":1918,"titleTemplate":6},"/docs/4.x/migration/configuration","docs/4.x/7.migration/2.configuration",{"title":276,"path":1920,"stem":1921,"titleTemplate":6},"/docs/4.x/migration/module-authors","docs/4.x/7.migration/20.module-authors",{"title":922,"path":1923,"stem":1924,"titleTemplate":6},"/docs/4.x/migration/auto-imports","docs/4.x/7.migration/3.auto-imports",{"title":932,"path":1926,"stem":1927,"titleTemplate":6},"/docs/4.x/migration/meta","docs/4.x/7.migration/4.meta",{"title":1058,"path":1929,"stem":1930,"titleTemplate":6},"/docs/4.x/migration/plugins-and-middleware","docs/4.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":1932,"stem":1933,"titleTemplate":6},"/docs/4.x/migration/pages-and-layouts","docs/4.x/7.migration/6.pages-and-layouts",{"title":1114,"path":1935,"stem":1936,"titleTemplate":6},"/docs/4.x/migration/component-options","docs/4.x/7.migration/7.component-options",{"title":399,"path":1938,"stem":1939,"titleTemplate":6},"/docs/4.x/migration/runtime-config","docs/4.x/7.migration/8.runtime-config",{"title":5,"titleTemplate":6,"icon":7,"path":1941,"stem":1942,"children":1943,"page":108},"/docs/5.x","docs/5.x",[1944,2002,2092,2219,2583,2660,2682,2716],{"title":12,"titleTemplate":13,"icon":14,"path":1945,"stem":1946,"children":1947,"page":108},"/docs/5.x/getting-started","docs/5.x/1.getting-started",[1948,1951,1954,1957,1960,1963,1966,1969,1972,1975,1978,1981,1984,1987,1990,1993,1996,1999],{"title":19,"path":1949,"stem":1950,"titleTemplate":6,"icon":22},"/docs/5.x/getting-started/introduction","docs/5.x/1.getting-started/01.introduction",{"title":24,"path":1952,"stem":1953,"titleTemplate":6,"icon":27},"/docs/5.x/getting-started/installation","docs/5.x/1.getting-started/02.installation",{"title":29,"path":1955,"stem":1956,"titleTemplate":6,"icon":32},"/docs/5.x/getting-started/configuration","docs/5.x/1.getting-started/03.configuration",{"title":34,"path":1958,"stem":1959,"titleTemplate":6,"icon":37},"/docs/5.x/getting-started/views","docs/5.x/1.getting-started/04.views",{"title":39,"path":1961,"stem":1962,"titleTemplate":6,"icon":42},"/docs/5.x/getting-started/assets","docs/5.x/1.getting-started/05.assets",{"title":44,"path":1964,"stem":1965,"titleTemplate":6,"icon":47},"/docs/5.x/getting-started/styling","docs/5.x/1.getting-started/06.styling",{"title":49,"path":1967,"stem":1968,"titleTemplate":6,"icon":52},"/docs/5.x/getting-started/routing","docs/5.x/1.getting-started/07.routing",{"title":54,"path":1970,"stem":1971,"titleTemplate":6,"icon":57},"/docs/5.x/getting-started/seo-meta","docs/5.x/1.getting-started/08.seo-meta",{"title":59,"path":1973,"stem":1974,"titleTemplate":6,"icon":62},"/docs/5.x/getting-started/transitions","docs/5.x/1.getting-started/09.transitions",{"title":64,"path":1976,"stem":1977,"titleTemplate":6,"icon":67},"/docs/5.x/getting-started/data-fetching","docs/5.x/1.getting-started/10.data-fetching",{"title":69,"path":1979,"stem":1980,"titleTemplate":6,"icon":72},"/docs/5.x/getting-started/state-management","docs/5.x/1.getting-started/11.state-management",{"title":74,"path":1982,"stem":1983,"titleTemplate":6,"icon":77},"/docs/5.x/getting-started/error-handling","docs/5.x/1.getting-started/12.error-handling",{"title":79,"path":1985,"stem":1986,"titleTemplate":6,"icon":82},"/docs/5.x/getting-started/server","docs/5.x/1.getting-started/13.server",{"title":84,"path":1988,"stem":1989,"titleTemplate":6,"icon":87},"/docs/5.x/getting-started/layers","docs/5.x/1.getting-started/14.layers",{"title":89,"path":1991,"stem":1992,"titleTemplate":6,"icon":92},"/docs/5.x/getting-started/prerendering","docs/5.x/1.getting-started/15.prerendering",{"title":94,"path":1994,"stem":1995,"titleTemplate":6,"icon":97},"/docs/5.x/getting-started/deployment","docs/5.x/1.getting-started/16.deployment",{"title":99,"path":1997,"stem":1998,"titleTemplate":6,"icon":102},"/docs/5.x/getting-started/testing","docs/5.x/1.getting-started/17.testing",{"title":104,"path":2000,"stem":2001,"titleTemplate":6,"icon":107},"/docs/5.x/getting-started/upgrade","docs/5.x/1.getting-started/18.upgrade",{"title":110,"titleTemplate":111,"icon":112,"path":2003,"stem":2004,"children":2005,"page":108},"/docs/5.x/directory-structure","docs/5.x/2.directory-structure",[2006,2009,2012,2050,2053,2056,2059,2062,2065,2068,2071,2074,2077,2080,2083,2086,2089],{"title":117,"path":2007,"stem":2008,"titleTemplate":6,"icon":120},"/docs/5.x/directory-structure/nuxt","docs/5.x/2.directory-structure/0.nuxt",{"title":122,"path":2010,"stem":2011,"titleTemplate":6,"icon":125},"/docs/5.x/directory-structure/output","docs/5.x/2.directory-structure/0.output",{"title":1193,"titleTemplate":111,"head":2013,"defaultOpen":1196,"icon":1197,"path":2014,"stem":2015,"children":2016,"page":108},{"title":1195},"/docs/5.x/directory-structure/app","docs/5.x/2.directory-structure/1.app",[2017,2020,2023,2026,2029,2032,2035,2038,2041,2044,2047],{"title":127,"path":2018,"stem":2019,"titleTemplate":6,"icon":130},"/docs/5.x/directory-structure/app/assets","docs/5.x/2.directory-structure/1.app/1.assets",{"title":132,"path":2021,"stem":2022,"titleTemplate":6,"icon":135},"/docs/5.x/directory-structure/app/components","docs/5.x/2.directory-structure/1.app/1.components",{"title":137,"path":2024,"stem":2025,"titleTemplate":6,"icon":140},"/docs/5.x/directory-structure/app/composables","docs/5.x/2.directory-structure/1.app/1.composables",{"title":152,"path":2027,"stem":2028,"titleTemplate":6,"icon":155},"/docs/5.x/directory-structure/app/layouts","docs/5.x/2.directory-structure/1.app/1.layouts",{"title":157,"path":2030,"stem":2031,"titleTemplate":6,"icon":160},"/docs/5.x/directory-structure/app/middleware","docs/5.x/2.directory-structure/1.app/1.middleware",{"title":171,"path":2033,"stem":2034,"titleTemplate":6,"icon":155},"/docs/5.x/directory-structure/app/pages","docs/5.x/2.directory-structure/1.app/1.pages",{"title":175,"path":2036,"stem":2037,"titleTemplate":6,"icon":178},"/docs/5.x/directory-structure/app/plugins","docs/5.x/2.directory-structure/1.app/1.plugins",{"title":195,"path":2039,"stem":2040,"titleTemplate":6,"icon":198},"/docs/5.x/directory-structure/app/utils","docs/5.x/2.directory-structure/1.app/1.utils",{"title":219,"path":2042,"stem":2043,"titleTemplate":6,"icon":222},"/docs/5.x/directory-structure/app/app","docs/5.x/2.directory-structure/1.app/3.app",{"title":224,"path":2045,"stem":2046,"titleTemplate":6,"icon":227},"/docs/5.x/directory-structure/app/app-config","docs/5.x/2.directory-structure/1.app/3.app-config",{"title":229,"path":2048,"stem":2049,"titleTemplate":6,"icon":222},"/docs/5.x/directory-structure/app/error","docs/5.x/2.directory-structure/1.app/3.error",{"title":142,"path":2051,"stem":2052,"titleTemplate":6,"icon":145},"/docs/5.x/directory-structure/content","docs/5.x/2.directory-structure/1.content",{"title":147,"path":2054,"stem":2055,"titleTemplate":6,"icon":150},"/docs/5.x/directory-structure/layers","docs/5.x/2.directory-structure/1.layers",{"title":162,"path":2057,"stem":2058,"titleTemplate":6,"icon":150},"/docs/5.x/directory-structure/modules","docs/5.x/2.directory-structure/1.modules",{"title":166,"path":2060,"stem":2061,"titleTemplate":6,"icon":169},"/docs/5.x/directory-structure/node_modules","docs/5.x/2.directory-structure/1.node_modules",{"title":180,"path":2063,"stem":2064,"titleTemplate":6,"icon":183},"/docs/5.x/directory-structure/public","docs/5.x/2.directory-structure/1.public",{"title":185,"path":2066,"stem":2067,"titleTemplate":6,"icon":188},"/docs/5.x/directory-structure/server","docs/5.x/2.directory-structure/1.server",{"title":190,"path":2069,"stem":2070,"titleTemplate":6,"icon":193},"/docs/5.x/directory-structure/shared","docs/5.x/2.directory-structure/1.shared",{"title":200,"path":2072,"stem":2073,"titleTemplate":6,"icon":203},"/docs/5.x/directory-structure/env","docs/5.x/2.directory-structure/2.env",{"title":205,"path":2075,"stem":2076,"titleTemplate":6,"icon":208},"/docs/5.x/directory-structure/gitignore","docs/5.x/2.directory-structure/2.gitignore",{"title":210,"path":2078,"stem":2079,"titleTemplate":6,"icon":213},"/docs/5.x/directory-structure/nuxtignore","docs/5.x/2.directory-structure/2.nuxtignore",{"title":215,"path":2081,"stem":2082,"titleTemplate":6,"icon":213},"/docs/5.x/directory-structure/nuxtrc","docs/5.x/2.directory-structure/2.nuxtrc",{"title":233,"path":2084,"stem":2085,"titleTemplate":6,"icon":213},"/docs/5.x/directory-structure/nuxt-config","docs/5.x/2.directory-structure/3.nuxt-config",{"title":237,"path":2087,"stem":2088,"titleTemplate":6,"icon":240},"/docs/5.x/directory-structure/package","docs/5.x/2.directory-structure/3.package",{"title":242,"path":2090,"stem":2091,"titleTemplate":6,"icon":245},"/docs/5.x/directory-structure/tsconfig","docs/5.x/2.directory-structure/3.tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":2093,"stem":2094,"children":2095,"page":108},"/docs/5.x/guide","docs/5.x/3.guide",[2096,2121,2134,2144,2169,2185],{"title":253,"titleTemplate":254,"icon":255,"path":2097,"stem":2098,"children":2099,"page":108},"/docs/5.x/guide/concepts","docs/5.x/3.guide/1.concepts",[2100,2103,2106,2109,2112,2115,2118],{"title":260,"path":2101,"stem":2102,"titleTemplate":6},"/docs/5.x/guide/concepts/rendering","docs/5.x/3.guide/1.concepts/1.rendering",{"title":264,"path":2104,"stem":2105,"titleTemplate":6},"/docs/5.x/guide/concepts/nuxt-lifecycle","docs/5.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":2107,"stem":2108,"titleTemplate":6},"/docs/5.x/guide/concepts/auto-imports","docs/5.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":2110,"stem":2111,"titleTemplate":6},"/docs/5.x/guide/concepts/server-engine","docs/5.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":2113,"stem":2114,"titleTemplate":6},"/docs/5.x/guide/concepts/modules","docs/5.x/3.guide/1.concepts/5.modules",{"title":280,"path":2116,"stem":2117,"titleTemplate":6},"/docs/5.x/guide/concepts/typescript","docs/5.x/3.guide/1.concepts/8.typescript",{"title":284,"path":2119,"stem":2120,"titleTemplate":6},"/docs/5.x/guide/concepts/code-style","docs/5.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":2122,"stem":2123,"children":2124,"page":108},"/docs/5.x/guide/best-practices","docs/5.x/3.guide/2.best-practices",[2125,2128,2131],{"title":1310,"path":2126,"stem":2127,"titleTemplate":6},"/docs/5.x/guide/best-practices/hydration","docs/5.x/3.guide/2.best-practices/hydration",{"title":299,"path":2129,"stem":2130,"titleTemplate":6},"/docs/5.x/guide/best-practices/performance","docs/5.x/3.guide/2.best-practices/performance",{"title":303,"path":2132,"stem":2133,"titleTemplate":6},"/docs/5.x/guide/best-practices/plugins","docs/5.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":2135,"stem":2136,"children":2137,"page":108},"/docs/5.x/guide/ai","docs/5.x/3.guide/3.ai",[2138,2141],{"title":314,"path":2139,"stem":2140,"titleTemplate":6},"/docs/5.x/guide/ai/mcp","docs/5.x/3.guide/3.ai/1.mcp",{"title":318,"path":2142,"stem":2143,"titleTemplate":6},"/docs/5.x/guide/ai/llms-txt","docs/5.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":2145,"stem":2146,"children":2147,"page":108},"/docs/5.x/guide/modules","docs/5.x/3.guide/4.modules",[2148,2151,2154,2157,2160,2163,2166],{"title":329,"path":2149,"stem":2150,"titleTemplate":6},"/docs/5.x/guide/modules/getting-started","docs/5.x/3.guide/4.modules/1.getting-started",{"title":333,"path":2152,"stem":2153,"titleTemplate":6},"/docs/5.x/guide/modules/module-anatomy","docs/5.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":2155,"stem":2156,"titleTemplate":6},"/docs/5.x/guide/modules/recipes-basics","docs/5.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":2158,"stem":2159,"titleTemplate":6},"/docs/5.x/guide/modules/recipes-advanced","docs/5.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":2161,"stem":2162,"titleTemplate":6},"/docs/5.x/guide/modules/testing","docs/5.x/3.guide/4.modules/5.testing",{"title":349,"path":2164,"stem":2165,"titleTemplate":6},"/docs/5.x/guide/modules/best-practices","docs/5.x/3.guide/4.modules/6.best-practices",{"title":353,"path":2167,"stem":2168,"titleTemplate":6},"/docs/5.x/guide/modules/ecosystem","docs/5.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":2170,"stem":2171,"children":2172,"page":108},"/docs/5.x/guide/recipes","docs/5.x/3.guide/5.recipes",[2173,2176,2179,2182],{"title":364,"path":2174,"stem":2175,"titleTemplate":6},"/docs/5.x/guide/recipes/custom-routing","docs/5.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":2177,"stem":2178,"titleTemplate":6},"/docs/5.x/guide/recipes/vite-plugin","docs/5.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":2180,"stem":2181,"titleTemplate":6},"/docs/5.x/guide/recipes/custom-usefetch","docs/5.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":2183,"stem":2184,"titleTemplate":6},"/docs/5.x/guide/recipes/sessions-and-authentication","docs/5.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":2186,"stem":2187,"children":2188,"page":108},"/docs/5.x/guide/going-further","docs/5.x/3.guide/6.going-further",[2189,2192,2195,2198,2201,2204,2207,2210,2213,2216],{"title":387,"path":2190,"stem":2191,"titleTemplate":6},"/docs/5.x/guide/going-further/events","docs/5.x/3.guide/6.going-further/1.events",{"title":391,"path":2193,"stem":2194,"titleTemplate":6},"/docs/5.x/guide/going-further/experimental-features","docs/5.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":2196,"stem":2197,"titleTemplate":6},"/docs/5.x/guide/going-further/features","docs/5.x/3.guide/6.going-further/1.features",{"title":399,"path":2199,"stem":2200,"titleTemplate":6},"/docs/5.x/guide/going-further/runtime-config","docs/5.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":2202,"stem":2203,"titleTemplate":6},"/docs/5.x/guide/going-further/nightly-release-channel","docs/5.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":2205,"stem":2206,"titleTemplate":6},"/docs/5.x/guide/going-further/hooks","docs/5.x/3.guide/6.going-further/2.hooks",{"title":411,"path":2208,"stem":2209,"titleTemplate":6},"/docs/5.x/guide/going-further/kit","docs/5.x/3.guide/6.going-further/4.kit",{"title":415,"path":2211,"stem":2212,"titleTemplate":6},"/docs/5.x/guide/going-further/nuxt-app","docs/5.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":2214,"stem":2215,"titleTemplate":6},"/docs/5.x/guide/going-further/layers","docs/5.x/3.guide/6.going-further/7.layers",{"title":423,"path":2217,"stem":2218,"titleTemplate":6},"/docs/5.x/guide/going-further/debugging","docs/5.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":2220,"stem":2221,"children":2222,"page":108},"/docs/5.x/api","docs/5.x/4.api",[2223,2275,2369,2460,2512,2570,2580],{"title":434,"titleTemplate":435,"icon":324,"path":2224,"stem":2225,"children":2226,"page":108},"/docs/5.x/api/components","docs/5.x/4.api/1.components",[2227,2230,2233,2236,2239,2242,2245,2248,2251,2254,2257,2260,2263,2266,2269,2272],{"title":440,"path":2228,"stem":2229,"titleTemplate":6},"/docs/5.x/api/components/client-only","docs/5.x/4.api/1.components/1.client-only",{"title":444,"path":2231,"stem":2232,"titleTemplate":6},"/docs/5.x/api/components/dev-only","docs/5.x/4.api/1.components/1.dev-only",{"title":448,"path":2234,"stem":2235,"titleTemplate":6},"/docs/5.x/api/components/nuxt-client-fallback","docs/5.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":2237,"stem":2238,"titleTemplate":6},"/docs/5.x/api/components/nuxt-picture","docs/5.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":2240,"stem":2241,"titleTemplate":6},"/docs/5.x/api/components/teleports","docs/5.x/4.api/1.components/11.teleports",{"title":460,"path":2243,"stem":2244,"titleTemplate":6},"/docs/5.x/api/components/nuxt-route-announcer","docs/5.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":2246,"stem":2247,"titleTemplate":6},"/docs/5.x/api/components/nuxt-time","docs/5.x/4.api/1.components/13.nuxt-time",{"title":1434,"path":2249,"stem":2250,"titleTemplate":6},"/docs/5.x/api/components/nuxt-announcer","docs/5.x/4.api/1.components/14.nuxt-announcer",{"title":468,"path":2252,"stem":2253,"titleTemplate":6},"/docs/5.x/api/components/nuxt-page","docs/5.x/4.api/1.components/2.nuxt-page",{"title":472,"path":2255,"stem":2256,"titleTemplate":6},"/docs/5.x/api/components/nuxt-layout","docs/5.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":2258,"stem":2259,"titleTemplate":6},"/docs/5.x/api/components/nuxt-link","docs/5.x/4.api/1.components/4.nuxt-link",{"title":480,"path":2261,"stem":2262,"titleTemplate":6},"/docs/5.x/api/components/nuxt-loading-indicator","docs/5.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":2264,"stem":2265,"titleTemplate":6},"/docs/5.x/api/components/nuxt-error-boundary","docs/5.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":2267,"stem":2268,"titleTemplate":6},"/docs/5.x/api/components/nuxt-welcome","docs/5.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":2270,"stem":2271,"titleTemplate":6},"/docs/5.x/api/components/nuxt-island","docs/5.x/4.api/1.components/8.nuxt-island",{"title":496,"path":2273,"stem":2274,"titleTemplate":6},"/docs/5.x/api/components/nuxt-img","docs/5.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":2276,"stem":2277,"children":2278,"page":108},"/docs/5.x/api/composables","docs/5.x/4.api/2.composables",[2279,2282,2285,2288,2291,2294,2297,2300,2303,2306,2309,2312,2315,2318,2321,2324,2327,2330,2333,2336,2339,2342,2345,2348,2351,2354,2357,2360,2363,2366],{"title":507,"path":2280,"stem":2281,"titleTemplate":6},"/docs/5.x/api/composables/on-prehydrate","docs/5.x/4.api/2.composables/on-prehydrate",{"title":1469,"path":2283,"stem":2284,"titleTemplate":6},"/docs/5.x/api/composables/use-announcer","docs/5.x/4.api/2.composables/use-announcer",{"title":511,"path":2286,"stem":2287,"titleTemplate":6},"/docs/5.x/api/composables/use-app-config","docs/5.x/4.api/2.composables/use-app-config",{"title":515,"path":2289,"stem":2290,"titleTemplate":6},"/docs/5.x/api/composables/use-async-data","docs/5.x/4.api/2.composables/use-async-data",{"title":519,"path":2292,"stem":2293,"titleTemplate":6},"/docs/5.x/api/composables/use-cookie","docs/5.x/4.api/2.composables/use-cookie",{"title":523,"path":2295,"stem":2296,"titleTemplate":6},"/docs/5.x/api/composables/use-error","docs/5.x/4.api/2.composables/use-error",{"title":527,"path":2298,"stem":2299,"titleTemplate":6},"/docs/5.x/api/composables/use-fetch","docs/5.x/4.api/2.composables/use-fetch",{"title":531,"path":2301,"stem":2302,"titleTemplate":6},"/docs/5.x/api/composables/use-head","docs/5.x/4.api/2.composables/use-head",{"title":535,"path":2304,"stem":2305,"titleTemplate":6},"/docs/5.x/api/composables/use-head-safe","docs/5.x/4.api/2.composables/use-head-safe",{"title":539,"path":2307,"stem":2308,"titleTemplate":6},"/docs/5.x/api/composables/use-hydration","docs/5.x/4.api/2.composables/use-hydration",{"title":543,"path":2310,"stem":2311,"titleTemplate":6},"/docs/5.x/api/composables/use-lazy-async-data","docs/5.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":2313,"stem":2314,"titleTemplate":6},"/docs/5.x/api/composables/use-lazy-fetch","docs/5.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":2316,"stem":2317,"titleTemplate":6},"/docs/5.x/api/composables/use-loading-indicator","docs/5.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":2319,"stem":2320,"titleTemplate":6},"/docs/5.x/api/composables/use-nuxt-app","docs/5.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":2322,"stem":2323,"titleTemplate":6},"/docs/5.x/api/composables/use-nuxt-data","docs/5.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":2325,"stem":2326,"titleTemplate":6},"/docs/5.x/api/composables/use-preview-mode","docs/5.x/4.api/2.composables/use-preview-mode",{"title":567,"path":2328,"stem":2329,"titleTemplate":6},"/docs/5.x/api/composables/use-request-event","docs/5.x/4.api/2.composables/use-request-event",{"title":571,"path":2331,"stem":2332,"titleTemplate":6},"/docs/5.x/api/composables/use-request-fetch","docs/5.x/4.api/2.composables/use-request-fetch",{"title":575,"path":2334,"stem":2335,"titleTemplate":6},"/docs/5.x/api/composables/use-request-header","docs/5.x/4.api/2.composables/use-request-header",{"title":579,"path":2337,"stem":2338,"titleTemplate":6},"/docs/5.x/api/composables/use-request-headers","docs/5.x/4.api/2.composables/use-request-headers",{"title":583,"path":2340,"stem":2341,"titleTemplate":6},"/docs/5.x/api/composables/use-request-url","docs/5.x/4.api/2.composables/use-request-url",{"title":587,"path":2343,"stem":2344,"titleTemplate":6},"/docs/5.x/api/composables/use-response-header","docs/5.x/4.api/2.composables/use-response-header",{"title":591,"path":2346,"stem":2347,"titleTemplate":6},"/docs/5.x/api/composables/use-route","docs/5.x/4.api/2.composables/use-route",{"title":595,"path":2349,"stem":2350,"titleTemplate":6},"/docs/5.x/api/composables/use-route-announcer","docs/5.x/4.api/2.composables/use-route-announcer",{"title":599,"path":2352,"stem":2353,"titleTemplate":6},"/docs/5.x/api/composables/use-router","docs/5.x/4.api/2.composables/use-router",{"title":603,"path":2355,"stem":2356,"titleTemplate":6},"/docs/5.x/api/composables/use-runtime-config","docs/5.x/4.api/2.composables/use-runtime-config",{"title":607,"path":2358,"stem":2359,"titleTemplate":6},"/docs/5.x/api/composables/use-runtime-hook","docs/5.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":2361,"stem":2362,"titleTemplate":6},"/docs/5.x/api/composables/use-seo-meta","docs/5.x/4.api/2.composables/use-seo-meta",{"title":615,"path":2364,"stem":2365,"titleTemplate":6},"/docs/5.x/api/composables/use-server-seo-meta","docs/5.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":2367,"stem":2368,"titleTemplate":6},"/docs/5.x/api/composables/use-state","docs/5.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":2370,"stem":2371,"children":2372,"page":108},"/docs/5.x/api/utils","docs/5.x/4.api/3.utils",[2373,2376,2379,2382,2385,2388,2391,2394,2397,2400,2403,2406,2409,2412,2415,2418,2421,2424,2427,2430,2433,2436,2439,2442,2445,2448,2451,2454,2457],{"title":630,"path":2374,"stem":2375,"titleTemplate":6},"/docs/5.x/api/utils/dollarfetch","docs/5.x/4.api/3.utils/$fetch",{"title":634,"path":2377,"stem":2378,"titleTemplate":6},"/docs/5.x/api/utils/abort-navigation","docs/5.x/4.api/3.utils/abort-navigation",{"title":638,"path":2380,"stem":2381,"titleTemplate":6},"/docs/5.x/api/utils/add-route-middleware","docs/5.x/4.api/3.utils/add-route-middleware",{"title":642,"path":2383,"stem":2384,"titleTemplate":6},"/docs/5.x/api/utils/call-once","docs/5.x/4.api/3.utils/call-once",{"title":646,"path":2386,"stem":2387,"titleTemplate":6},"/docs/5.x/api/utils/clear-error","docs/5.x/4.api/3.utils/clear-error",{"title":650,"path":2389,"stem":2390,"titleTemplate":6},"/docs/5.x/api/utils/clear-nuxt-data","docs/5.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":2392,"stem":2393,"titleTemplate":6},"/docs/5.x/api/utils/clear-nuxt-state","docs/5.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":2395,"stem":2396,"titleTemplate":6},"/docs/5.x/api/utils/create-error","docs/5.x/4.api/3.utils/create-error",{"title":662,"path":2398,"stem":2399,"titleTemplate":6},"/docs/5.x/api/utils/define-lazy-hydration-component","docs/5.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":2401,"stem":2402,"titleTemplate":6},"/docs/5.x/api/utils/define-nuxt-component","docs/5.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":2404,"stem":2405,"titleTemplate":6},"/docs/5.x/api/utils/define-nuxt-plugin","docs/5.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":2407,"stem":2408,"titleTemplate":6},"/docs/5.x/api/utils/define-nuxt-route-middleware","docs/5.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":2410,"stem":2411,"titleTemplate":6},"/docs/5.x/api/utils/define-page-meta","docs/5.x/4.api/3.utils/define-page-meta",{"title":682,"path":2413,"stem":2414,"titleTemplate":6},"/docs/5.x/api/utils/define-route-rules","docs/5.x/4.api/3.utils/define-route-rules",{"title":686,"path":2416,"stem":2417,"titleTemplate":6},"/docs/5.x/api/utils/navigate-to","docs/5.x/4.api/3.utils/navigate-to",{"title":690,"path":2419,"stem":2420,"titleTemplate":6},"/docs/5.x/api/utils/on-before-route-leave","docs/5.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":2422,"stem":2423,"titleTemplate":6},"/docs/5.x/api/utils/on-before-route-update","docs/5.x/4.api/3.utils/on-before-route-update",{"title":698,"path":2425,"stem":2426,"titleTemplate":6},"/docs/5.x/api/utils/on-nuxt-ready","docs/5.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":2428,"stem":2429,"titleTemplate":6},"/docs/5.x/api/utils/prefetch-components","docs/5.x/4.api/3.utils/prefetch-components",{"title":706,"path":2431,"stem":2432,"titleTemplate":6},"/docs/5.x/api/utils/preload-components","docs/5.x/4.api/3.utils/preload-components",{"title":710,"path":2434,"stem":2435,"titleTemplate":6},"/docs/5.x/api/utils/preload-route-components","docs/5.x/4.api/3.utils/preload-route-components",{"title":714,"path":2437,"stem":2438,"titleTemplate":6},"/docs/5.x/api/utils/prerender-routes","docs/5.x/4.api/3.utils/prerender-routes",{"title":718,"path":2440,"stem":2441,"titleTemplate":6},"/docs/5.x/api/utils/refresh-cookie","docs/5.x/4.api/3.utils/refresh-cookie",{"title":722,"path":2443,"stem":2444,"titleTemplate":6},"/docs/5.x/api/utils/refresh-nuxt-data","docs/5.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":2446,"stem":2447,"titleTemplate":6},"/docs/5.x/api/utils/reload-nuxt-app","docs/5.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":2449,"stem":2450,"titleTemplate":6},"/docs/5.x/api/utils/set-page-layout","docs/5.x/4.api/3.utils/set-page-layout",{"title":734,"path":2452,"stem":2453,"titleTemplate":6},"/docs/5.x/api/utils/set-response-status","docs/5.x/4.api/3.utils/set-response-status",{"title":738,"path":2455,"stem":2456,"titleTemplate":6},"/docs/5.x/api/utils/show-error","docs/5.x/4.api/3.utils/show-error",{"title":742,"path":2458,"stem":2459,"titleTemplate":6},"/docs/5.x/api/utils/update-app-config","docs/5.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":2461,"stem":2462,"children":2463,"page":108},"/docs/5.x/api/commands","docs/5.x/4.api/4.commands",[2464,2467,2470,2473,2476,2479,2482,2485,2488,2491,2494,2497,2500,2503,2506,2509],{"title":753,"path":2465,"stem":2466,"titleTemplate":6},"/docs/5.x/api/commands/add","docs/5.x/4.api/4.commands/add",{"title":757,"path":2468,"stem":2469,"titleTemplate":6},"/docs/5.x/api/commands/analyze","docs/5.x/4.api/4.commands/analyze",{"title":761,"path":2471,"stem":2472,"titleTemplate":6},"/docs/5.x/api/commands/build","docs/5.x/4.api/4.commands/build",{"title":765,"path":2474,"stem":2475,"titleTemplate":6},"/docs/5.x/api/commands/build-module","docs/5.x/4.api/4.commands/build-module",{"title":769,"path":2477,"stem":2478,"titleTemplate":6},"/docs/5.x/api/commands/cleanup","docs/5.x/4.api/4.commands/cleanup",{"title":773,"path":2480,"stem":2481,"titleTemplate":6},"/docs/5.x/api/commands/dev","docs/5.x/4.api/4.commands/dev",{"title":777,"path":2483,"stem":2484,"titleTemplate":6},"/docs/5.x/api/commands/devtools","docs/5.x/4.api/4.commands/devtools",{"title":781,"path":2486,"stem":2487,"titleTemplate":6},"/docs/5.x/api/commands/generate","docs/5.x/4.api/4.commands/generate",{"title":785,"path":2489,"stem":2490,"titleTemplate":6},"/docs/5.x/api/commands/info","docs/5.x/4.api/4.commands/info",{"title":789,"path":2492,"stem":2493,"titleTemplate":6},"/docs/5.x/api/commands/init","docs/5.x/4.api/4.commands/init",{"title":793,"path":2495,"stem":2496,"titleTemplate":6},"/docs/5.x/api/commands/module","docs/5.x/4.api/4.commands/module",{"title":797,"path":2498,"stem":2499,"titleTemplate":6},"/docs/5.x/api/commands/prepare","docs/5.x/4.api/4.commands/prepare",{"title":801,"path":2501,"stem":2502,"titleTemplate":6},"/docs/5.x/api/commands/preview","docs/5.x/4.api/4.commands/preview",{"title":805,"path":2504,"stem":2505,"titleTemplate":6},"/docs/5.x/api/commands/test","docs/5.x/4.api/4.commands/test",{"title":809,"path":2507,"stem":2508,"titleTemplate":6},"/docs/5.x/api/commands/typecheck","docs/5.x/4.api/4.commands/typecheck",{"title":813,"path":2510,"stem":2511,"titleTemplate":6},"/docs/5.x/api/commands/upgrade","docs/5.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":2513,"stem":2514,"children":2515,"page":108},"/docs/5.x/api/kit","docs/5.x/4.api/5.kit",[2516,2519,2522,2525,2528,2531,2534,2537,2540,2543,2546,2549,2552,2555,2558,2561,2564,2567],{"title":276,"path":2517,"stem":2518,"titleTemplate":6},"/docs/5.x/api/kit/modules","docs/5.x/4.api/5.kit/1.modules",{"title":399,"path":2520,"stem":2521,"titleTemplate":6},"/docs/5.x/api/kit/runtime-config","docs/5.x/4.api/5.kit/10.runtime-config",{"title":829,"path":2523,"stem":2524,"titleTemplate":6},"/docs/5.x/api/kit/templates","docs/5.x/4.api/5.kit/10.templates",{"title":833,"path":2526,"stem":2527,"titleTemplate":6},"/docs/5.x/api/kit/nitro","docs/5.x/4.api/5.kit/11.nitro",{"title":837,"path":2529,"stem":2530,"titleTemplate":6},"/docs/5.x/api/kit/resolving","docs/5.x/4.api/5.kit/12.resolving",{"title":841,"path":2532,"stem":2533,"titleTemplate":6},"/docs/5.x/api/kit/logging","docs/5.x/4.api/5.kit/13.logging",{"title":845,"path":2535,"stem":2536,"titleTemplate":6},"/docs/5.x/api/kit/builder","docs/5.x/4.api/5.kit/14.builder",{"title":849,"path":2538,"stem":2539,"titleTemplate":6},"/docs/5.x/api/kit/examples","docs/5.x/4.api/5.kit/15.examples",{"title":84,"path":2541,"stem":2542,"titleTemplate":6},"/docs/5.x/api/kit/layers","docs/5.x/4.api/5.kit/16.layers",{"title":856,"path":2544,"stem":2545,"titleTemplate":6},"/docs/5.x/api/kit/programmatic","docs/5.x/4.api/5.kit/2.programmatic",{"title":860,"path":2547,"stem":2548,"titleTemplate":6},"/docs/5.x/api/kit/compatibility","docs/5.x/4.api/5.kit/3.compatibility",{"title":268,"path":2550,"stem":2551,"titleTemplate":6},"/docs/5.x/api/kit/autoimports","docs/5.x/4.api/5.kit/4.autoimports",{"title":434,"path":2553,"stem":2554,"titleTemplate":6},"/docs/5.x/api/kit/components","docs/5.x/4.api/5.kit/5.components",{"title":870,"path":2556,"stem":2557,"titleTemplate":6},"/docs/5.x/api/kit/context","docs/5.x/4.api/5.kit/6.context",{"title":874,"path":2559,"stem":2560,"titleTemplate":6},"/docs/5.x/api/kit/pages","docs/5.x/4.api/5.kit/7.pages",{"title":878,"path":2562,"stem":2563,"titleTemplate":6},"/docs/5.x/api/kit/layout","docs/5.x/4.api/5.kit/8.layout",{"title":882,"path":2565,"stem":2566,"titleTemplate":6},"/docs/5.x/api/kit/head","docs/5.x/4.api/5.kit/9.head",{"title":886,"path":2568,"stem":2569,"titleTemplate":6},"/docs/5.x/api/kit/plugins","docs/5.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":2571,"stem":2572,"children":2573,"page":108},"/docs/5.x/api/advanced","docs/5.x/4.api/6.advanced",[2574,2577],{"title":407,"path":2575,"stem":2576,"titleTemplate":6},"/docs/5.x/api/advanced/hooks","docs/5.x/4.api/6.advanced/1.hooks",{"title":899,"path":2578,"stem":2579,"titleTemplate":6},"/docs/5.x/api/advanced/import-meta","docs/5.x/4.api/6.advanced/2.import-meta",{"title":903,"path":2581,"stem":2582,"titleTemplate":906,"icon":32},"/docs/5.x/api/nuxt-config","docs/5.x/4.api/6.nuxt-config",{"title":849,"titleTemplate":908,"icon":909,"path":2584,"stem":2585,"children":2586,"page":108},"/docs/5.x/examples","docs/5.x/4.examples",[2587,2590,2609,2622,2653],{"title":914,"path":2588,"stem":2589,"titleTemplate":6},"/docs/5.x/examples/hello-world","docs/5.x/4.examples/0.hello-world",{"title":395,"path":2591,"stem":2592,"children":2593,"page":108},"/docs/5.x/examples/features","docs/5.x/4.examples/1.features",[2594,2597,2600,2603,2606],{"title":922,"path":2595,"stem":2596,"titleTemplate":6},"/docs/5.x/examples/features/auto-imports","docs/5.x/4.examples/1.features/1.auto-imports",{"title":64,"path":2598,"stem":2599,"titleTemplate":6},"/docs/5.x/examples/features/data-fetching","docs/5.x/4.examples/1.features/2.data-fetching",{"title":69,"path":2601,"stem":2602,"titleTemplate":6},"/docs/5.x/examples/features/state-management","docs/5.x/4.examples/1.features/3.state-management",{"title":932,"path":2604,"stem":2605,"titleTemplate":6},"/docs/5.x/examples/features/meta-tags","docs/5.x/4.examples/1.features/4.meta-tags",{"title":936,"path":2607,"stem":2608,"titleTemplate":6},"/docs/5.x/examples/features/layouts","docs/5.x/4.examples/1.features/5.layouts",{"title":49,"path":2610,"stem":2611,"children":2612,"page":108},"/docs/5.x/examples/routing","docs/5.x/4.examples/2.routing",[2613,2616,2619],{"title":944,"path":2614,"stem":2615,"titleTemplate":6},"/docs/5.x/examples/routing/middleware","docs/5.x/4.examples/2.routing/middleware",{"title":874,"path":2617,"stem":2618,"titleTemplate":6},"/docs/5.x/examples/routing/pages","docs/5.x/4.examples/2.routing/pages",{"title":951,"path":2620,"stem":2621,"titleTemplate":6},"/docs/5.x/examples/routing/universal-router","docs/5.x/4.examples/2.routing/universal-router",{"title":890,"path":2623,"stem":2624,"children":2625,"page":108},"/docs/5.x/examples/advanced","docs/5.x/4.examples/4.advanced",[2626,2629,2632,2635,2638,2641,2644,2647,2650],{"title":84,"path":2627,"stem":2628,"titleTemplate":6},"/docs/5.x/examples/advanced/config-extends","docs/5.x/4.examples/4.advanced/config-extends",{"title":74,"path":2630,"stem":2631,"titleTemplate":6},"/docs/5.x/examples/advanced/error-handling","docs/5.x/4.examples/4.advanced/error-handling",{"title":965,"path":2633,"stem":2634,"titleTemplate":6},"/docs/5.x/examples/advanced/jsx","docs/5.x/4.examples/4.advanced/jsx",{"title":969,"path":2636,"stem":2637,"titleTemplate":6},"/docs/5.x/examples/advanced/locale","docs/5.x/4.examples/4.advanced/locale",{"title":973,"path":2639,"stem":2640,"titleTemplate":6},"/docs/5.x/examples/advanced/module-extend-pages","docs/5.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":2642,"stem":2643,"titleTemplate":6},"/docs/5.x/examples/advanced/teleport","docs/5.x/4.examples/4.advanced/teleport",{"title":99,"path":2645,"stem":2646,"titleTemplate":6},"/docs/5.x/examples/advanced/testing","docs/5.x/4.examples/4.advanced/testing",{"title":519,"path":2648,"stem":2649,"titleTemplate":6},"/docs/5.x/examples/advanced/use-cookie","docs/5.x/4.examples/4.advanced/use-cookie",{"title":987,"path":2651,"stem":2652,"titleTemplate":6},"/docs/5.x/examples/advanced/use-custom-fetch-composable","docs/5.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":2654,"stem":2655,"children":2656,"page":108},"/docs/5.x/examples/experimental","docs/5.x/4.examples/7.experimental",[2657],{"title":996,"path":2658,"stem":2659,"titleTemplate":6},"/docs/5.x/examples/experimental/wasm","docs/5.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":2661,"stem":2662,"children":2663,"page":108},"/docs/5.x/community","docs/5.x/5.community",[2664,2667,2670,2673,2676,2679],{"title":1007,"path":2665,"stem":2666,"titleTemplate":6,"icon":1010},"/docs/5.x/community/getting-help","docs/5.x/5.community/2.getting-help",{"title":1012,"path":2668,"stem":2669,"titleTemplate":6,"icon":1015},"/docs/5.x/community/reporting-bugs","docs/5.x/5.community/3.reporting-bugs",{"title":1017,"path":2671,"stem":2672,"titleTemplate":6,"icon":1020},"/docs/5.x/community/contribution","docs/5.x/5.community/4.contribution",{"title":1022,"path":2674,"stem":2675,"titleTemplate":6,"icon":1025},"/docs/5.x/community/framework-contribution","docs/5.x/5.community/5.framework-contribution",{"title":1027,"path":2677,"stem":2678,"titleTemplate":6,"icon":1030},"/docs/5.x/community/roadmap","docs/5.x/5.community/6.roadmap",{"title":1032,"path":2680,"stem":2681,"titleTemplate":6,"icon":1035},"/docs/5.x/community/changelog","docs/5.x/5.community/7.changelog",{"title":1037,"titleTemplate":1038,"icon":1039,"path":2683,"stem":2684,"children":2685,"page":108},"/docs/5.x/bridge","docs/5.x/6.bridge",[2686,2689,2692,2695,2698,2701,2704,2707,2710,2713],{"title":1044,"path":2687,"stem":2688,"titleTemplate":6},"/docs/5.x/bridge/overview","docs/5.x/6.bridge/1.overview",{"title":29,"path":2690,"stem":2691,"titleTemplate":6},"/docs/5.x/bridge/configuration","docs/5.x/6.bridge/10.configuration",{"title":280,"path":2693,"stem":2694,"titleTemplate":6},"/docs/5.x/bridge/typescript","docs/5.x/6.bridge/2.typescript",{"title":1054,"path":2696,"stem":2697,"titleTemplate":6},"/docs/5.x/bridge/bridge-composition-api","docs/5.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":2699,"stem":2700,"titleTemplate":6},"/docs/5.x/bridge/plugins-and-middleware","docs/5.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":2702,"stem":2703,"titleTemplate":6},"/docs/5.x/bridge/nuxt3-compatible-api","docs/5.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":2705,"stem":2706,"titleTemplate":6},"/docs/5.x/bridge/meta","docs/5.x/6.bridge/6.meta",{"title":399,"path":2708,"stem":2709,"titleTemplate":6},"/docs/5.x/bridge/runtime-config","docs/5.x/6.bridge/7.runtime-config",{"title":833,"path":2711,"stem":2712,"titleTemplate":6},"/docs/5.x/bridge/nitro","docs/5.x/6.bridge/8.nitro",{"title":1075,"path":2714,"stem":2715,"titleTemplate":6},"/docs/5.x/bridge/vite","docs/5.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":2717,"stem":2718,"children":2719,"page":108},"/docs/5.x/migration","docs/5.x/7.migration",[2720,2723,2726,2729,2732,2735,2738,2741,2744,2747,2750],{"title":1044,"path":2721,"stem":2722,"titleTemplate":6},"/docs/5.x/migration/overview","docs/5.x/7.migration/1.overview",{"title":1088,"path":2724,"stem":2725,"titleTemplate":6},"/docs/5.x/migration/bundling","docs/5.x/7.migration/10.bundling",{"title":79,"path":2727,"stem":2728,"titleTemplate":6},"/docs/5.x/migration/server","docs/5.x/7.migration/11.server",{"title":29,"path":2730,"stem":2731,"titleTemplate":6},"/docs/5.x/migration/configuration","docs/5.x/7.migration/2.configuration",{"title":276,"path":2733,"stem":2734,"titleTemplate":6},"/docs/5.x/migration/module-authors","docs/5.x/7.migration/20.module-authors",{"title":922,"path":2736,"stem":2737,"titleTemplate":6},"/docs/5.x/migration/auto-imports","docs/5.x/7.migration/3.auto-imports",{"title":932,"path":2739,"stem":2740,"titleTemplate":6},"/docs/5.x/migration/meta","docs/5.x/7.migration/4.meta",{"title":1058,"path":2742,"stem":2743,"titleTemplate":6},"/docs/5.x/migration/plugins-and-middleware","docs/5.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":2745,"stem":2746,"titleTemplate":6},"/docs/5.x/migration/pages-and-layouts","docs/5.x/7.migration/6.pages-and-layouts",{"title":1114,"path":2748,"stem":2749,"titleTemplate":6},"/docs/5.x/migration/component-options","docs/5.x/7.migration/7.component-options",{"title":399,"path":2751,"stem":2752,"titleTemplate":6},"/docs/5.x/migration/runtime-config","docs/5.x/7.migration/8.runtime-config",{"title":2754,"path":2755,"stem":2756,"children":2757,"page":108},"Blog","/blog","blog",[2758,2762,2766,2770,2774,2778,2782,2786,2790,2794,2798,2802,2806,2810,2814,2818,2822,2826,2830,2834,2838],{"title":2759,"path":2760,"stem":2761},"Announcing 3.0","/blog/v3","blog/1.v3",{"title":2763,"path":2764,"stem":2765},"Nuxt 3.3","/blog/v3-3","blog/10.v3-3",{"title":2767,"path":2768,"stem":2769},"Nuxt 3.4","/blog/v3-4","blog/11.v3-4",{"title":2771,"path":2772,"stem":2773},"Nuxt 3.5","/blog/v3-5","blog/12.v3-5",{"title":2775,"path":2776,"stem":2777},"Nuxt 3.6","/blog/v3-6","blog/13.v3-6",{"title":2779,"path":2780,"stem":2781},"Nuxt on the Edge","/blog/nuxt-on-the-edge","blog/14.nuxt-on-the-edge",{"title":2783,"path":2784,"stem":2785},"Nuxt DevTools v1.0","/blog/nuxt-devtools-v1-0","blog/18.nuxt-devtools-v1-0",{"title":2787,"path":2788,"stem":2789},"Nuxt: A vision for 2023","/blog/vision-2023","blog/2.vision-2023",{"title":2791,"path":2792,"stem":2793},"The Evolution of Shiki v1.0","/blog/shiki-v1","blog/21.shiki-v1",{"title":2795,"path":2796,"stem":2797},"Refreshed Nuxt ESLint Integrations","/blog/eslint-module","blog/24.eslint-module",{"title":2799,"path":2800,"stem":2801},"Introducing Nuxt Scripts","/blog/nuxt-scripts","blog/26.nuxt-scripts",{"title":2803,"path":2804,"stem":2805},"Introducing Nuxt Icon v1","/blog/nuxt-icon-v1-0","blog/29.nuxt-icon-v1-0",{"title":2807,"path":2808,"stem":2809},"Introducing Nuxt DevTools","/blog/introducing-nuxt-devtools","blog/3.introducing-nuxt-devtools",{"title":2811,"path":2812,"stem":2813},"Announcing Nuxt 3 Release Candidate","/blog/nuxt3-rc","blog/3.nuxt3-rc",{"title":2815,"path":2816,"stem":2817},"Nuxt 2 End-of-Life (EOL)","/blog/nuxt2-eol","blog/4.nuxt2-eol",{"title":2819,"path":2820,"stem":2821},"Introducing Nuxt 3 Beta","/blog/nuxt3-beta","blog/4.nuxt3-beta",{"title":2823,"path":2824,"stem":2825},"Going Full Static","/blog/going-full-static","blog/5.going-full-static",{"title":2827,"path":2828,"stem":2829},"Introducing Smart Prefetching","/blog/introducing-smart-prefetching","blog/6.introducing-smart-prefetching",{"title":2831,"path":2832,"stem":2833},"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":2835,"path":2836,"stem":2837},"Nuxt 2 Static Improvements","/blog/nuxt-static-improvements","blog/8.nuxt-static-improvements",{"title":2839,"path":2840,"stem":2841},"Nuxt 2: From Terminal to Browser","/blog/nuxtjs-from-terminal-to-browser","blog/9.nuxtjs-from-terminal-to-browser",{"v5":2843,"v4":2843,"v3":2844,"v2":2845},"4.3.1","3.21.1","2.18.1",{"id":2847,"title":132,"body":2848,"description":6362,"extension":6363,"links":6,"meta":6364,"navigation":6367,"path":133,"seo":6368,"stem":134,"titleTemplate":6,"__hash__":6369},"docsv3/docs/3.x/2.directory-structure/1.components.md",{"type":2849,"value":2850,"toc":6341},"minimark",[2851,2855,2902,2982,2987,2990,3032,3035,3049,3063,3074,3176,3190,3194,3239,3242,3393,3402,3407,3410,3450,3461,3470,3474,3481,3487,3675,3679,3682,3685,3688,3693,3696,3705,3717,3723,3726,3775,3785,3800,3805,3808,3811,3859,3870,3875,3878,3935,3949,3960,3965,3968,4025,4036,4041,4044,4101,4106,4109,4256,4260,4263,4311,4315,4322,4458,4462,4465,4529,4533,4539,4765,4769,4775,4953,4958,4962,4976,5165,5169,5183,5265,5269,5276,5297,5349,5357,5375,5383,5387,5390,5397,5401,5410,5414,5417,5420,5423,5471,5478,5500,5578,5594,5599,5604,5609,5614,5618,5627,5634,5725,5738,5742,5752,5755,5780,5785,5792,5804,5808,5817,5847,5897,5901,5909,5911,5915,5918,5931,5934,6018,6028,6190,6197,6240,6249,6328,6334,6337],[2852,2853,2854],"p",{},"Nuxt automatically imports any components in this directory (along with components that are registered by any modules you may be using).",[2856,2857,2862],"pre",{"className":2858,"code":2859,"filename":110,"language":2860,"meta":2861,"style":2861},"language-bash shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","-| components/\n---| AppHeader.vue\n---| AppFooter.vue\n","bash","",[2863,2864,2865,2881,2892],"code",{"__ignoreMap":2861},[2866,2867,2870,2874,2878],"span",{"class":2868,"line":2869},"line",1,[2866,2871,2873],{"class":2872},"s52Pk","-",[2866,2875,2877],{"class":2876},"sDfIl","|",[2866,2879,2880],{"class":2872}," components/\n",[2866,2882,2884,2887,2889],{"class":2868,"line":2883},2,[2866,2885,2886],{"class":2872},"---",[2866,2888,2877],{"class":2876},[2866,2890,2891],{"class":2872}," AppHeader.vue\n",[2866,2893,2895,2897,2899],{"class":2868,"line":2894},3,[2866,2896,2886],{"class":2872},[2866,2898,2877],{"class":2876},[2866,2900,2901],{"class":2872}," AppFooter.vue\n",[2856,2903,2907],{"className":2904,"code":2905,"filename":219,"language":2906,"meta":2861,"style":2861},"language-html shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","\u003Ctemplate>\n  \u003Cdiv>\n    \u003CAppHeader />\n    \u003CNuxtPage />\n    \u003CAppFooter />\n  \u003C/div>\n\u003C/template>\n","html",[2863,2908,2909,2921,2931,2942,2952,2962,2972],{"__ignoreMap":2861},[2866,2910,2911,2914,2918],{"class":2868,"line":2869},[2866,2912,2913],{"class":2876},"\u003C",[2866,2915,2917],{"class":2916},"sRlkE","template",[2866,2919,2920],{"class":2876},">\n",[2866,2922,2923,2926,2929],{"class":2868,"line":2883},[2866,2924,2925],{"class":2876},"  \u003C",[2866,2927,2928],{"class":2916},"div",[2866,2930,2920],{"class":2876},[2866,2932,2933,2936,2939],{"class":2868,"line":2894},[2866,2934,2935],{"class":2876},"    \u003C",[2866,2937,2938],{"class":2916},"AppHeader",[2866,2940,2941],{"class":2876}," />\n",[2866,2943,2945,2947,2950],{"class":2868,"line":2944},4,[2866,2946,2935],{"class":2876},[2866,2948,2949],{"class":2916},"NuxtPage",[2866,2951,2941],{"class":2876},[2866,2953,2955,2957,2960],{"class":2868,"line":2954},5,[2866,2956,2935],{"class":2876},[2866,2958,2959],{"class":2916},"AppFooter",[2866,2961,2941],{"class":2876},[2866,2963,2965,2968,2970],{"class":2868,"line":2964},6,[2866,2966,2967],{"class":2876},"  \u003C/",[2866,2969,2928],{"class":2916},[2866,2971,2920],{"class":2876},[2866,2973,2975,2978,2980],{"class":2868,"line":2974},7,[2866,2976,2977],{"class":2876},"\u003C/",[2866,2979,2917],{"class":2916},[2866,2981,2920],{"class":2876},[2983,2984,2986],"h2",{"id":2985},"component-names","Component Names",[2852,2988,2989],{},"If you have a component in nested directories such as:",[2856,2991,2993],{"className":2858,"code":2992,"filename":110,"language":2860,"meta":2861,"style":2861},"-| components/\n---| base/\n-----| foo/\n-------| Button.vue\n",[2863,2994,2995,3003,3012,3022],{"__ignoreMap":2861},[2866,2996,2997,2999,3001],{"class":2868,"line":2869},[2866,2998,2873],{"class":2872},[2866,3000,2877],{"class":2876},[2866,3002,2880],{"class":2872},[2866,3004,3005,3007,3009],{"class":2868,"line":2883},[2866,3006,2886],{"class":2872},[2866,3008,2877],{"class":2876},[2866,3010,3011],{"class":2872}," base/\n",[2866,3013,3014,3017,3019],{"class":2868,"line":2894},[2866,3015,3016],{"class":2872},"-----",[2866,3018,2877],{"class":2876},[2866,3020,3021],{"class":2872}," foo/\n",[2866,3023,3024,3027,3029],{"class":2868,"line":2944},[2866,3025,3026],{"class":2872},"-------",[2866,3028,2877],{"class":2876},[2866,3030,3031],{"class":2872}," Button.vue\n",[2852,3033,3034],{},"... then the component's name will be based on its own path directory and filename, with duplicate segments being removed. Therefore, the component's name will be:",[2856,3036,3038],{"className":2904,"code":3037,"language":2906,"meta":2861,"style":2861},"\u003CBaseFooButton />\n",[2863,3039,3040],{"__ignoreMap":2861},[2866,3041,3042,3044,3047],{"class":2868,"line":2869},[2866,3043,2913],{"class":2876},[2866,3045,3046],{"class":2916},"BaseFooButton",[2866,3048,2941],{"class":2876},[3050,3051,3052],"note",{},[2852,3053,3054,3055,3058,3059,3062],{},"For clarity, we recommend that the component's filename matches its name. So, in the example above, you could rename ",[2863,3056,3057],{},"Button.vue"," to be ",[2863,3060,3061],{},"BaseFooButton.vue",".",[2852,3064,3065,3066,3069,3070,3073],{},"If you want to auto-import components based only on its name, not path, then you need to set ",[2863,3067,3068],{},"pathPrefix"," option to ",[2863,3071,3072],{},"false"," using extended form of the configuration object:",[2856,3075,3080],{"className":3076,"code":3077,"filename":233,"language":3078,"meta":3079,"style":2861},"language-ts shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight has-diff","export default defineNuxtConfig({\n  components: [\n    {\n      path: '~/components',\n      pathPrefix: false, // [!code ++]\n    },\n  ],\n})\n","ts","twoslash",[2863,3081,3082,3102,3113,3118,3138,3155,3160,3167],{"__ignoreMap":2861},[2866,3083,3084,3088,3091,3095,3099],{"class":2868,"line":2869},[2866,3085,3087],{"class":3086},"s8R28","export",[2866,3089,3090],{"class":3086}," default",[2866,3092,3094],{"class":3093},"s3cPz"," defineNuxtConfig",[2866,3096,3098],{"class":3097},"sZSNi","(",[2866,3100,3101],{"class":2876},"{\n",[2866,3103,3104,3107,3110],{"class":2868,"line":2883},[2866,3105,3106],{"class":2916},"  components",[2866,3108,3109],{"class":2876},":",[2866,3111,3112],{"class":3097}," [\n",[2866,3114,3115],{"class":2868,"line":2894},[2866,3116,3117],{"class":2876},"    {\n",[2866,3119,3120,3123,3125,3128,3132,3135],{"class":2868,"line":2944},[2866,3121,3122],{"class":2916},"      path",[2866,3124,3109],{"class":2876},[2866,3126,3127],{"class":2876}," '",[2866,3129,3131],{"class":3130},"sGFVr","~/components",[2866,3133,3134],{"class":2876},"'",[2866,3136,3137],{"class":2876},",\n",[2866,3139,3143,3146,3148,3152],{"class":3140,"line":2954},[2868,3141,3142],"diff","add",[2866,3144,3145],{"class":2916},"      pathPrefix",[2866,3147,3109],{"class":2876},[2866,3149,3151],{"class":3150},"sbKd-"," false",[2866,3153,3154],{"class":2876},",",[2866,3156,3157],{"class":2868,"line":2964},[2866,3158,3159],{"class":2876},"    },\n",[2866,3161,3162,3165],{"class":2868,"line":2974},[2866,3163,3164],{"class":3097},"  ]",[2866,3166,3137],{"class":2876},[2866,3168,3170,3173],{"class":2868,"line":3169},8,[2866,3171,3172],{"class":2876},"}",[2866,3174,3175],{"class":3097},")\n",[2852,3177,3178,3179,3182,3183,3186,3187,3062],{},"This registers the components using the same strategy as used in Nuxt 2. For example, ",[2863,3180,3181],{},"~/components/Some/MyComponent.vue"," will be usable as ",[2863,3184,3185],{},"\u003CMyComponent>"," and not ",[2863,3188,3189],{},"\u003CSomeMyComponent>",[2983,3191,3193],{"id":3192},"dynamic-components","Dynamic Components",[2852,3195,3196,3197,3227,3228,3231,3232,3235,3236,3238],{},"If you want to use the Vue ",[2863,3198,3201,3203,3206,3209,3213,3216,3219,3222,3224],{"className":3199,"language":3200,"style":2861},"language-vue shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","vue",[2866,3202,2913],{"class":2876},[2866,3204,3205],{"class":2916},"component",[2866,3207,3208],{"class":2876}," :",[2866,3210,3212],{"class":3211},"smZ93","is",[2866,3214,3215],{"class":2876},"=",[2866,3217,3218],{"class":2876},"\"",[2866,3220,3221],{"class":3097},"someComputedComponent",[2866,3223,3218],{"class":2876},[2866,3225,3226],{"class":2876},">"," syntax, you need to use the ",[2863,3229,3230],{},"resolveComponent"," helper provided by Vue or import the component directly from ",[2863,3233,3234],{},"#components"," and pass it into ",[2863,3237,3212],{}," prop.",[2852,3240,3241],{},"For example:",[2856,3243,3246],{"className":3199,"code":3244,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Cscript setup lang=\"ts\">\nimport { SomeComponent } from '#components'\n\nconst MyButton = resolveComponent('MyButton')\n\u003C/script>\n\n\u003Ctemplate>\n  \u003Ccomponent :is=\"clickable ? MyButton : 'div'\" />\n  \u003Ccomponent :is=\"SomeComponent\" />\n\u003C/template>\n","pages/index.vue",[2863,3247,3248,3271,3295,3300,3324,3332,3336,3344,3364,3384],{"__ignoreMap":2861},[2866,3249,3250,3252,3255,3258,3261,3263,3265,3267,3269],{"class":2868,"line":2869},[2866,3251,2913],{"class":2876},[2866,3253,3254],{"class":2916},"script",[2866,3256,3257],{"class":3211}," setup",[2866,3259,3260],{"class":3211}," lang",[2866,3262,3215],{"class":2876},[2866,3264,3218],{"class":2876},[2866,3266,3078],{"class":3130},[2866,3268,3218],{"class":2876},[2866,3270,2920],{"class":2876},[2866,3272,3273,3276,3279,3282,3285,3288,3290,3292],{"class":2868,"line":2883},[2866,3274,3275],{"class":3086},"import",[2866,3277,3278],{"class":2876}," {",[2866,3280,3281],{"class":3097}," SomeComponent",[2866,3283,3284],{"class":2876}," }",[2866,3286,3287],{"class":3086}," from",[2866,3289,3127],{"class":2876},[2866,3291,3234],{"class":3130},[2866,3293,3294],{"class":2876},"'\n",[2866,3296,3297],{"class":2868,"line":2894},[2866,3298,3299],{"emptyLinePlaceholder":1196},"\n",[2866,3301,3302,3305,3308,3310,3313,3315,3317,3320,3322],{"class":2868,"line":2944},[2866,3303,3304],{"class":3211},"const",[2866,3306,3307],{"class":3097}," MyButton ",[2866,3309,3215],{"class":2876},[2866,3311,3312],{"class":3093}," resolveComponent",[2866,3314,3098],{"class":3097},[2866,3316,3134],{"class":2876},[2866,3318,3319],{"class":3130},"MyButton",[2866,3321,3134],{"class":2876},[2866,3323,3175],{"class":3097},[2866,3325,3326,3328,3330],{"class":2868,"line":2954},[2866,3327,2977],{"class":2876},[2866,3329,3254],{"class":2916},[2866,3331,2920],{"class":2876},[2866,3333,3334],{"class":2868,"line":2964},[2866,3335,3299],{"emptyLinePlaceholder":1196},[2866,3337,3338,3340,3342],{"class":2868,"line":2974},[2866,3339,2913],{"class":2876},[2866,3341,2917],{"class":2916},[2866,3343,2920],{"class":2876},[2866,3345,3346,3348,3350,3353,3355,3357,3360,3362],{"class":2868,"line":3169},[2866,3347,2925],{"class":2876},[2866,3349,3205],{"class":2916},[2866,3351,3352],{"class":3211}," :is",[2866,3354,3215],{"class":2876},[2866,3356,3218],{"class":2876},[2866,3358,3359],{"class":3130},"clickable ? MyButton : 'div'",[2866,3361,3218],{"class":2876},[2866,3363,2941],{"class":2876},[2866,3365,3367,3369,3371,3373,3375,3377,3380,3382],{"class":2868,"line":3366},9,[2866,3368,2925],{"class":2876},[2866,3370,3205],{"class":2916},[2866,3372,3352],{"class":3211},[2866,3374,3215],{"class":2876},[2866,3376,3218],{"class":2876},[2866,3378,3379],{"class":3130},"SomeComponent",[2866,3381,3218],{"class":2876},[2866,3383,2941],{"class":2876},[2866,3385,3387,3389,3391],{"class":2868,"line":3386},10,[2866,3388,2977],{"class":2876},[2866,3390,2917],{"class":2916},[2866,3392,2920],{"class":2876},[3394,3395,3396],"important",{},[2852,3397,3398,3399,3401],{},"If you are using ",[2863,3400,3230],{}," to handle dynamic components, make sure not to insert anything but the name of the component, which must be a literal string and not be or contain a variable. The string is statically analyzed at the compilation step.",[3403,3404],"video-accordion",{"title":3405,"video-id":3406},"Watch Daniel Roe's short video about resolveComponent()","4kq8E5IUM2U",[2852,3408,3409],{},"Alternatively, though not recommended, you can register all your components globally, which will create async chunks for all your components and make them available throughout your application.",[2856,3411,3414],{"className":3412,"code":3413,"language":3141,"meta":2861,"style":2861},"language-diff shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","  export default defineNuxtConfig({\n    components: {\n+     global: true,\n+     dirs: ['~/components']\n    },\n  })\n",[2863,3415,3416,3421,3426,3434,3441,3445],{"__ignoreMap":2861},[2866,3417,3418],{"class":2868,"line":2869},[2866,3419,3420],{"class":3097},"  export default defineNuxtConfig({\n",[2866,3422,3423],{"class":2868,"line":2883},[2866,3424,3425],{"class":3097},"    components: {\n",[2866,3427,3428,3431],{"class":2868,"line":2894},[2866,3429,3430],{"class":2876},"+",[2866,3432,3433],{"class":3130},"     global: true,\n",[2866,3435,3436,3438],{"class":2868,"line":2944},[2866,3437,3430],{"class":2876},[2866,3439,3440],{"class":3130},"     dirs: ['~/components']\n",[2866,3442,3443],{"class":2868,"line":2954},[2866,3444,3159],{"class":3097},[2866,3446,3447],{"class":2868,"line":2964},[2866,3448,3449],{"class":3097},"  })\n",[2852,3451,3452,3453,3456,3457,3460],{},"You can also selectively register some components globally by placing them in a ",[2863,3454,3455],{},"~/components/global"," directory, or by using a ",[2863,3458,3459],{},".global.vue"," suffix in the filename. As noted above, each global component is rendered in a separate chunk, so be careful not to overuse this feature.",[3050,3462,3463],{},[2852,3464,3465,3466,3469],{},"The ",[2863,3467,3468],{},"global"," option can also be set per component directory.",[2983,3471,3473],{"id":3472},"dynamic-imports","Dynamic Imports",[2852,3475,3476,3477,3480],{},"To dynamically import a component (also known as lazy-loading a component) all you need to do is add the ",[2863,3478,3479],{},"Lazy"," prefix to the component's name. This is particularly useful if the component is not always needed.",[2852,3482,3483,3484,3486],{},"By using the ",[2863,3485,3479],{}," prefix you can delay loading the component code until the right moment, which can be helpful for optimizing your JavaScript bundle size.",[2856,3488,3490],{"className":3199,"code":3489,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Cscript setup lang=\"ts\">\nconst show = ref(false)\n\u003C/script>\n\n\u003Ctemplate>\n  \u003Cdiv>\n    \u003Ch1>Mountains\u003C/h1>\n    \u003CLazyMountainsList v-if=\"show\" />\n    \u003Cbutton\n      v-if=\"!show\"\n      @click=\"show = true\"\n    >\n      Show List\n    \u003C/button>\n  \u003C/div>\n\u003C/template>\n",[2863,3491,3492,3512,3530,3538,3542,3550,3558,3576,3597,3604,3619,3634,3640,3646,3657,3666],{"__ignoreMap":2861},[2866,3493,3494,3496,3498,3500,3502,3504,3506,3508,3510],{"class":2868,"line":2869},[2866,3495,2913],{"class":2876},[2866,3497,3254],{"class":2916},[2866,3499,3257],{"class":3211},[2866,3501,3260],{"class":3211},[2866,3503,3215],{"class":2876},[2866,3505,3218],{"class":2876},[2866,3507,3078],{"class":3130},[2866,3509,3218],{"class":2876},[2866,3511,2920],{"class":2876},[2866,3513,3514,3516,3519,3521,3524,3526,3528],{"class":2868,"line":2883},[2866,3515,3304],{"class":3211},[2866,3517,3518],{"class":3097}," show ",[2866,3520,3215],{"class":2876},[2866,3522,3523],{"class":3093}," ref",[2866,3525,3098],{"class":3097},[2866,3527,3072],{"class":3150},[2866,3529,3175],{"class":3097},[2866,3531,3532,3534,3536],{"class":2868,"line":2894},[2866,3533,2977],{"class":2876},[2866,3535,3254],{"class":2916},[2866,3537,2920],{"class":2876},[2866,3539,3540],{"class":2868,"line":2944},[2866,3541,3299],{"emptyLinePlaceholder":1196},[2866,3543,3544,3546,3548],{"class":2868,"line":2954},[2866,3545,2913],{"class":2876},[2866,3547,2917],{"class":2916},[2866,3549,2920],{"class":2876},[2866,3551,3552,3554,3556],{"class":2868,"line":2964},[2866,3553,2925],{"class":2876},[2866,3555,2928],{"class":2916},[2866,3557,2920],{"class":2876},[2866,3559,3560,3562,3565,3567,3570,3572,3574],{"class":2868,"line":2974},[2866,3561,2935],{"class":2876},[2866,3563,3564],{"class":2916},"h1",[2866,3566,3226],{"class":2876},[2866,3568,3569],{"class":3097},"Mountains",[2866,3571,2977],{"class":2876},[2866,3573,3564],{"class":2916},[2866,3575,2920],{"class":2876},[2866,3577,3578,3580,3583,3586,3588,3590,3593,3595],{"class":2868,"line":3169},[2866,3579,2935],{"class":2876},[2866,3581,3582],{"class":2916},"LazyMountainsList",[2866,3584,3585],{"class":3211}," v-if",[2866,3587,3215],{"class":2876},[2866,3589,3218],{"class":2876},[2866,3591,3592],{"class":3130},"show",[2866,3594,3218],{"class":2876},[2866,3596,2941],{"class":2876},[2866,3598,3599,3601],{"class":2868,"line":3366},[2866,3600,2935],{"class":2876},[2866,3602,3603],{"class":2916},"button\n",[2866,3605,3606,3609,3611,3613,3616],{"class":2868,"line":3386},[2866,3607,3608],{"class":3211},"      v-if",[2866,3610,3215],{"class":2876},[2866,3612,3218],{"class":2876},[2866,3614,3615],{"class":3130},"!show",[2866,3617,3618],{"class":2876},"\"\n",[2866,3620,3622,3625,3627,3629,3632],{"class":2868,"line":3621},11,[2866,3623,3624],{"class":3211},"      @click",[2866,3626,3215],{"class":2876},[2866,3628,3218],{"class":2876},[2866,3630,3631],{"class":3130},"show = true",[2866,3633,3618],{"class":2876},[2866,3635,3637],{"class":2868,"line":3636},12,[2866,3638,3639],{"class":2876},"    >\n",[2866,3641,3643],{"class":2868,"line":3642},13,[2866,3644,3645],{"class":3097},"      Show List\n",[2866,3647,3649,3652,3655],{"class":2868,"line":3648},14,[2866,3650,3651],{"class":2876},"    \u003C/",[2866,3653,3654],{"class":2916},"button",[2866,3656,2920],{"class":2876},[2866,3658,3660,3662,3664],{"class":2868,"line":3659},15,[2866,3661,2967],{"class":2876},[2866,3663,2928],{"class":2916},[2866,3665,2920],{"class":2876},[2866,3667,3669,3671,3673],{"class":2868,"line":3668},16,[2866,3670,2977],{"class":2876},[2866,3672,2917],{"class":2916},[2866,3674,2920],{"class":2876},[2983,3676,3678],{"id":3677},"delayed-or-lazy-hydration","Delayed (or Lazy) Hydration",[2852,3680,3681],{},"Lazy components are great for controlling the chunk sizes in your app, but they don't always enhance runtime performance, as they still load eagerly unless conditionally rendered. In real-world applications, some pages may include a lot of content and a lot of components, and most of the time not all of them need to be interactive as soon as the page is loaded. Having them all load eagerly can negatively impact performance.",[2852,3683,3684],{},"In order to optimize your app, you may want to delay the hydration of some components until they're visible, or until the browser is done with more important tasks.",[2852,3686,3687],{},"Nuxt supports this using lazy (or delayed) hydration, allowing you to control when components become interactive.",[3689,3690,3692],"h3",{"id":3691},"hydration-strategies","Hydration Strategies",[2852,3694,3695],{},"Nuxt provides a range of built-in hydration strategies. Only one strategy can be used per lazy component.",[3050,3697,3698],{},[2852,3699,3700,3701,3704],{},"Any prop change on a lazily hydrated component will trigger hydration immediately. (e.g., changing a prop on a component with ",[2863,3702,3703],{},"hydrate-never"," will cause it to hydrate)",[3706,3707,3708],"warning",{},[2852,3709,3710,3711,3714,3715,3062],{},"Currently Nuxt's built-in lazy hydration only works in single-file components (SFCs), and requires you to define the prop in the template (rather than spreading an object of props via ",[2863,3712,3713],{},"v-bind","). It also does not work with direct imports from ",[2863,3716,3234],{},[3718,3719,3721],"h4",{"id":3720},"hydrate-on-visible",[2863,3722,3720],{},[2852,3724,3725],{},"Hydrates the component when it becomes visible in the viewport.",[2856,3727,3729],{"className":3199,"code":3728,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-visible />\n  \u003C/div>\n\u003C/template>\n",[2863,3730,3731,3739,3747,3759,3767],{"__ignoreMap":2861},[2866,3732,3733,3735,3737],{"class":2868,"line":2869},[2866,3734,2913],{"class":2876},[2866,3736,2917],{"class":2916},[2866,3738,2920],{"class":2876},[2866,3740,3741,3743,3745],{"class":2868,"line":2883},[2866,3742,2925],{"class":2876},[2866,3744,2928],{"class":2916},[2866,3746,2920],{"class":2876},[2866,3748,3749,3751,3754,3757],{"class":2868,"line":2894},[2866,3750,2935],{"class":2876},[2866,3752,3753],{"class":2916},"LazyMyComponent",[2866,3755,3756],{"class":3211}," hydrate-on-visible",[2866,3758,2941],{"class":2876},[2866,3760,3761,3763,3765],{"class":2868,"line":2944},[2866,3762,2967],{"class":2876},[2866,3764,2928],{"class":2916},[2866,3766,2920],{"class":2876},[2866,3768,3769,3771,3773],{"class":2868,"line":2954},[2866,3770,2977],{"class":2876},[2866,3772,2917],{"class":2916},[2866,3774,2920],{"class":2876},[3776,3777,3780],"read-more",{"to":3778,"title":3779},"https://developer.mozilla.org/en-US/docs/Web/API/IntersectionObserver/IntersectionObserver","IntersectionObserver options",[2852,3781,3782,3783,3062],{},"Read more about the options for ",[2863,3784,3720],{},[3050,3786,3787],{},[2852,3788,3789,3790,3062],{},"Under the hood, this uses Vue's built-in ",[3791,3792,3796,3799],"a",{"href":3793,"rel":3794},"https://vuejs.org/guide/components/async#hydrate-on-visible",[3795],"nofollow",[2863,3797,3798],{},"hydrateOnVisible"," strategy",[3718,3801,3803],{"id":3802},"hydrate-on-idle",[2863,3804,3802],{},[2852,3806,3807],{},"Hydrates the component when the browser is idle. This is suitable if you need the component to load as soon as possible, but not block the critical rendering path.",[2852,3809,3810],{},"You can also pass a number which serves as a max timeout.",[2856,3812,3814],{"className":3199,"code":3813,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-idle />\n  \u003C/div>\n\u003C/template>\n",[2863,3815,3816,3824,3832,3843,3851],{"__ignoreMap":2861},[2866,3817,3818,3820,3822],{"class":2868,"line":2869},[2866,3819,2913],{"class":2876},[2866,3821,2917],{"class":2916},[2866,3823,2920],{"class":2876},[2866,3825,3826,3828,3830],{"class":2868,"line":2883},[2866,3827,2925],{"class":2876},[2866,3829,2928],{"class":2916},[2866,3831,2920],{"class":2876},[2866,3833,3834,3836,3838,3841],{"class":2868,"line":2894},[2866,3835,2935],{"class":2876},[2866,3837,3753],{"class":2916},[2866,3839,3840],{"class":3211}," hydrate-on-idle",[2866,3842,2941],{"class":2876},[2866,3844,3845,3847,3849],{"class":2868,"line":2944},[2866,3846,2967],{"class":2876},[2866,3848,2928],{"class":2916},[2866,3850,2920],{"class":2876},[2866,3852,3853,3855,3857],{"class":2868,"line":2954},[2866,3854,2977],{"class":2876},[2866,3856,2917],{"class":2916},[2866,3858,2920],{"class":2876},[3050,3860,3861],{},[2852,3862,3789,3863,3062],{},[3791,3864,3867,3799],{"href":3865,"rel":3866},"https://vuejs.org/guide/components/async#hydrate-on-idle",[3795],[2863,3868,3869],{},"hydrateOnIdle",[3718,3871,3873],{"id":3872},"hydrate-on-interaction",[2863,3874,3872],{},[2852,3876,3877],{},"Hydrates the component after a specified interaction (e.g., click, mouseover).",[2856,3879,3881],{"className":3199,"code":3880,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-interaction=\"mouseover\" />\n  \u003C/div>\n\u003C/template>\n",[2863,3882,3883,3891,3899,3919,3927],{"__ignoreMap":2861},[2866,3884,3885,3887,3889],{"class":2868,"line":2869},[2866,3886,2913],{"class":2876},[2866,3888,2917],{"class":2916},[2866,3890,2920],{"class":2876},[2866,3892,3893,3895,3897],{"class":2868,"line":2883},[2866,3894,2925],{"class":2876},[2866,3896,2928],{"class":2916},[2866,3898,2920],{"class":2876},[2866,3900,3901,3903,3905,3908,3910,3912,3915,3917],{"class":2868,"line":2894},[2866,3902,2935],{"class":2876},[2866,3904,3753],{"class":2916},[2866,3906,3907],{"class":3211}," hydrate-on-interaction",[2866,3909,3215],{"class":2876},[2866,3911,3218],{"class":2876},[2866,3913,3914],{"class":3130},"mouseover",[2866,3916,3218],{"class":2876},[2866,3918,2941],{"class":2876},[2866,3920,3921,3923,3925],{"class":2868,"line":2944},[2866,3922,2967],{"class":2876},[2866,3924,2928],{"class":2916},[2866,3926,2920],{"class":2876},[2866,3928,3929,3931,3933],{"class":2868,"line":2954},[2866,3930,2977],{"class":2876},[2866,3932,2917],{"class":2916},[2866,3934,2920],{"class":2876},[2852,3936,3937,3938,3941,3942,3945,3946,3062],{},"If you do not pass an event or list of events, it defaults to hydrating on ",[2863,3939,3940],{},"pointerenter",", ",[2863,3943,3944],{},"click"," and ",[2863,3947,3948],{},"focus",[3050,3950,3951],{},[2852,3952,3789,3953,3062],{},[3791,3954,3957,3799],{"href":3955,"rel":3956},"https://vuejs.org/guide/components/async#hydrate-on-interaction",[3795],[2863,3958,3959],{},"hydrateOnInteraction",[3718,3961,3963],{"id":3962},"hydrate-on-media-query",[2863,3964,3962],{},[2852,3966,3967],{},"Hydrates the component when the window matches a media query.",[2856,3969,3971],{"className":3199,"code":3970,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-media-query=\"(max-width: 768px)\" />\n  \u003C/div>\n\u003C/template>\n",[2863,3972,3973,3981,3989,4009,4017],{"__ignoreMap":2861},[2866,3974,3975,3977,3979],{"class":2868,"line":2869},[2866,3976,2913],{"class":2876},[2866,3978,2917],{"class":2916},[2866,3980,2920],{"class":2876},[2866,3982,3983,3985,3987],{"class":2868,"line":2883},[2866,3984,2925],{"class":2876},[2866,3986,2928],{"class":2916},[2866,3988,2920],{"class":2876},[2866,3990,3991,3993,3995,3998,4000,4002,4005,4007],{"class":2868,"line":2894},[2866,3992,2935],{"class":2876},[2866,3994,3753],{"class":2916},[2866,3996,3997],{"class":3211}," hydrate-on-media-query",[2866,3999,3215],{"class":2876},[2866,4001,3218],{"class":2876},[2866,4003,4004],{"class":3130},"(max-width: 768px)",[2866,4006,3218],{"class":2876},[2866,4008,2941],{"class":2876},[2866,4010,4011,4013,4015],{"class":2868,"line":2944},[2866,4012,2967],{"class":2876},[2866,4014,2928],{"class":2916},[2866,4016,2920],{"class":2876},[2866,4018,4019,4021,4023],{"class":2868,"line":2954},[2866,4020,2977],{"class":2876},[2866,4022,2917],{"class":2916},[2866,4024,2920],{"class":2876},[3050,4026,4027],{},[2852,4028,3789,4029,3062],{},[3791,4030,4033,3799],{"href":4031,"rel":4032},"https://vuejs.org/guide/components/async#hydrate-on-media-query",[3795],[2863,4034,4035],{},"hydrateOnMediaQuery",[3718,4037,4039],{"id":4038},"hydrate-after",[2863,4040,4038],{},[2852,4042,4043],{},"Hydrates the component after a specified delay (in milliseconds).",[2856,4045,4047],{"className":3199,"code":4046,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent :hydrate-after=\"2000\" />\n  \u003C/div>\n\u003C/template>\n",[2863,4048,4049,4057,4065,4085,4093],{"__ignoreMap":2861},[2866,4050,4051,4053,4055],{"class":2868,"line":2869},[2866,4052,2913],{"class":2876},[2866,4054,2917],{"class":2916},[2866,4056,2920],{"class":2876},[2866,4058,4059,4061,4063],{"class":2868,"line":2883},[2866,4060,2925],{"class":2876},[2866,4062,2928],{"class":2916},[2866,4064,2920],{"class":2876},[2866,4066,4067,4069,4071,4074,4076,4078,4081,4083],{"class":2868,"line":2894},[2866,4068,2935],{"class":2876},[2866,4070,3753],{"class":2916},[2866,4072,4073],{"class":3211}," :hydrate-after",[2866,4075,3215],{"class":2876},[2866,4077,3218],{"class":2876},[2866,4079,4080],{"class":3130},"2000",[2866,4082,3218],{"class":2876},[2866,4084,2941],{"class":2876},[2866,4086,4087,4089,4091],{"class":2868,"line":2944},[2866,4088,2967],{"class":2876},[2866,4090,2928],{"class":2916},[2866,4092,2920],{"class":2876},[2866,4094,4095,4097,4099],{"class":2868,"line":2954},[2866,4096,2977],{"class":2876},[2866,4098,2917],{"class":2916},[2866,4100,2920],{"class":2876},[3718,4102,4104],{"id":4103},"hydrate-when",[2863,4105,4103],{},[2852,4107,4108],{},"Hydrates the component based on a boolean condition.",[2856,4110,4112],{"className":3199,"code":4111,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent :hydrate-when=\"isReady\" />\n  \u003C/div>\n\u003C/template>\n\n\u003Cscript setup lang=\"ts\">\nconst isReady = ref(false)\nfunction myFunction () {\n  // trigger custom hydration strategy...\n  isReady.value = true\n}\n\u003C/script>\n",[2863,4113,4114,4122,4130,4150,4158,4166,4170,4190,4207,4221,4227,4243,4248],{"__ignoreMap":2861},[2866,4115,4116,4118,4120],{"class":2868,"line":2869},[2866,4117,2913],{"class":2876},[2866,4119,2917],{"class":2916},[2866,4121,2920],{"class":2876},[2866,4123,4124,4126,4128],{"class":2868,"line":2883},[2866,4125,2925],{"class":2876},[2866,4127,2928],{"class":2916},[2866,4129,2920],{"class":2876},[2866,4131,4132,4134,4136,4139,4141,4143,4146,4148],{"class":2868,"line":2894},[2866,4133,2935],{"class":2876},[2866,4135,3753],{"class":2916},[2866,4137,4138],{"class":3211}," :hydrate-when",[2866,4140,3215],{"class":2876},[2866,4142,3218],{"class":2876},[2866,4144,4145],{"class":3130},"isReady",[2866,4147,3218],{"class":2876},[2866,4149,2941],{"class":2876},[2866,4151,4152,4154,4156],{"class":2868,"line":2944},[2866,4153,2967],{"class":2876},[2866,4155,2928],{"class":2916},[2866,4157,2920],{"class":2876},[2866,4159,4160,4162,4164],{"class":2868,"line":2954},[2866,4161,2977],{"class":2876},[2866,4163,2917],{"class":2916},[2866,4165,2920],{"class":2876},[2866,4167,4168],{"class":2868,"line":2964},[2866,4169,3299],{"emptyLinePlaceholder":1196},[2866,4171,4172,4174,4176,4178,4180,4182,4184,4186,4188],{"class":2868,"line":2974},[2866,4173,2913],{"class":2876},[2866,4175,3254],{"class":2916},[2866,4177,3257],{"class":3211},[2866,4179,3260],{"class":3211},[2866,4181,3215],{"class":2876},[2866,4183,3218],{"class":2876},[2866,4185,3078],{"class":3130},[2866,4187,3218],{"class":2876},[2866,4189,2920],{"class":2876},[2866,4191,4192,4194,4197,4199,4201,4203,4205],{"class":2868,"line":3169},[2866,4193,3304],{"class":3211},[2866,4195,4196],{"class":3097}," isReady ",[2866,4198,3215],{"class":2876},[2866,4200,3523],{"class":3093},[2866,4202,3098],{"class":3097},[2866,4204,3072],{"class":3150},[2866,4206,3175],{"class":3097},[2866,4208,4209,4212,4215,4218],{"class":2868,"line":3366},[2866,4210,4211],{"class":3211},"function",[2866,4213,4214],{"class":3093}," myFunction",[2866,4216,4217],{"class":2876}," ()",[2866,4219,4220],{"class":2876}," {\n",[2866,4222,4223],{"class":2868,"line":3386},[2866,4224,4226],{"class":4225},"sWuyu","  // trigger custom hydration strategy...\n",[2866,4228,4229,4232,4234,4237,4240],{"class":2868,"line":3621},[2866,4230,4231],{"class":3097},"  isReady",[2866,4233,3062],{"class":2876},[2866,4235,4236],{"class":3097},"value",[2866,4238,4239],{"class":2876}," =",[2866,4241,4242],{"class":3150}," true\n",[2866,4244,4245],{"class":2868,"line":3636},[2866,4246,4247],{"class":2876},"}\n",[2866,4249,4250,4252,4254],{"class":2868,"line":3642},[2866,4251,2977],{"class":2876},[2866,4253,3254],{"class":2916},[2866,4255,2920],{"class":2876},[3718,4257,4258],{"id":3703},[2863,4259,3703],{},[2852,4261,4262],{},"Never hydrates the component.",[2856,4264,4266],{"className":3199,"code":4265,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-never />\n  \u003C/div>\n\u003C/template>\n",[2863,4267,4268,4276,4284,4295,4303],{"__ignoreMap":2861},[2866,4269,4270,4272,4274],{"class":2868,"line":2869},[2866,4271,2913],{"class":2876},[2866,4273,2917],{"class":2916},[2866,4275,2920],{"class":2876},[2866,4277,4278,4280,4282],{"class":2868,"line":2883},[2866,4279,2925],{"class":2876},[2866,4281,2928],{"class":2916},[2866,4283,2920],{"class":2876},[2866,4285,4286,4288,4290,4293],{"class":2868,"line":2894},[2866,4287,2935],{"class":2876},[2866,4289,3753],{"class":2916},[2866,4291,4292],{"class":3211}," hydrate-never",[2866,4294,2941],{"class":2876},[2866,4296,4297,4299,4301],{"class":2868,"line":2944},[2866,4298,2967],{"class":2876},[2866,4300,2928],{"class":2916},[2866,4302,2920],{"class":2876},[2866,4304,4305,4307,4309],{"class":2868,"line":2954},[2866,4306,2977],{"class":2876},[2866,4308,2917],{"class":2916},[2866,4310,2920],{"class":2876},[3689,4312,4314],{"id":4313},"listening-to-hydration-events","Listening to Hydration Events",[2852,4316,4317,4318,4321],{},"All delayed hydration components emit a ",[2863,4319,4320],{},"@hydrated"," event when they are hydrated.",[2856,4323,4325],{"className":3199,"code":4324,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent\n      hydrate-on-visible\n      @hydrated=\"onHydrate\"\n    />\n  \u003C/div>\n\u003C/template>\n\n\u003Cscript setup lang=\"ts\">\nfunction onHydrate () {\n  console.log('Component has been hydrated!')\n}\n\u003C/script>\n",[2863,4326,4327,4335,4343,4350,4355,4369,4374,4382,4390,4394,4414,4425,4446,4450],{"__ignoreMap":2861},[2866,4328,4329,4331,4333],{"class":2868,"line":2869},[2866,4330,2913],{"class":2876},[2866,4332,2917],{"class":2916},[2866,4334,2920],{"class":2876},[2866,4336,4337,4339,4341],{"class":2868,"line":2883},[2866,4338,2925],{"class":2876},[2866,4340,2928],{"class":2916},[2866,4342,2920],{"class":2876},[2866,4344,4345,4347],{"class":2868,"line":2894},[2866,4346,2935],{"class":2876},[2866,4348,4349],{"class":2916},"LazyMyComponent\n",[2866,4351,4352],{"class":2868,"line":2944},[2866,4353,4354],{"class":3211},"      hydrate-on-visible\n",[2866,4356,4357,4360,4362,4364,4367],{"class":2868,"line":2954},[2866,4358,4359],{"class":3211},"      @hydrated",[2866,4361,3215],{"class":2876},[2866,4363,3218],{"class":2876},[2866,4365,4366],{"class":3130},"onHydrate",[2866,4368,3618],{"class":2876},[2866,4370,4371],{"class":2868,"line":2964},[2866,4372,4373],{"class":2876},"    />\n",[2866,4375,4376,4378,4380],{"class":2868,"line":2974},[2866,4377,2967],{"class":2876},[2866,4379,2928],{"class":2916},[2866,4381,2920],{"class":2876},[2866,4383,4384,4386,4388],{"class":2868,"line":3169},[2866,4385,2977],{"class":2876},[2866,4387,2917],{"class":2916},[2866,4389,2920],{"class":2876},[2866,4391,4392],{"class":2868,"line":3366},[2866,4393,3299],{"emptyLinePlaceholder":1196},[2866,4395,4396,4398,4400,4402,4404,4406,4408,4410,4412],{"class":2868,"line":3386},[2866,4397,2913],{"class":2876},[2866,4399,3254],{"class":2916},[2866,4401,3257],{"class":3211},[2866,4403,3260],{"class":3211},[2866,4405,3215],{"class":2876},[2866,4407,3218],{"class":2876},[2866,4409,3078],{"class":3130},[2866,4411,3218],{"class":2876},[2866,4413,2920],{"class":2876},[2866,4415,4416,4418,4421,4423],{"class":2868,"line":3621},[2866,4417,4211],{"class":3211},[2866,4419,4420],{"class":3093}," onHydrate",[2866,4422,4217],{"class":2876},[2866,4424,4220],{"class":2876},[2866,4426,4427,4430,4432,4435,4437,4439,4442,4444],{"class":2868,"line":3636},[2866,4428,4429],{"class":3097},"  console",[2866,4431,3062],{"class":2876},[2866,4433,4434],{"class":3093},"log",[2866,4436,3098],{"class":2916},[2866,4438,3134],{"class":2876},[2866,4440,4441],{"class":3130},"Component has been hydrated!",[2866,4443,3134],{"class":2876},[2866,4445,3175],{"class":2916},[2866,4447,4448],{"class":2868,"line":3642},[2866,4449,4247],{"class":2876},[2866,4451,4452,4454,4456],{"class":2868,"line":3648},[2866,4453,2977],{"class":2876},[2866,4455,3254],{"class":2916},[2866,4457,2920],{"class":2876},[3689,4459,4461],{"id":4460},"caveats-and-best-practices","Caveats and Best Practices",[2852,4463,4464],{},"Delayed hydration can offer performance benefits, but it's essential to use it correctly:",[4466,4467,4468,4476,4486,4496,4520],"ol",{},[4469,4470,4471,4475],"li",{},[4472,4473,4474],"strong",{},"Prioritize In-Viewport Content:"," Avoid delayed hydration for critical, above-the-fold content. It's best suited for content that isn't immediately needed.",[4469,4477,4478,4481,4482,4485],{},[4472,4479,4480],{},"Conditional Rendering:"," When using ",[2863,4483,4484],{},"v-if=\"false\""," on a lazy component, you might not need delayed hydration. You can just use a normal lazy component.",[4469,4487,4488,4491,4492,4495],{},[4472,4489,4490],{},"Shared State:"," Be mindful of shared state (",[2863,4493,4494],{},"v-model",") across multiple components. Updating the model in one component can trigger hydration in all components bound to that model.",[4469,4497,4498,4501,4502],{},[4472,4499,4500],{},"Use Each Strategy's Intended Use Case:"," Each strategy is optimized for a specific purpose.",[4503,4504,4505,4510,4515],"ul",{},[4469,4506,4507,4509],{},[2863,4508,4103],{}," is best for components that might not always need to be hydrated.",[4469,4511,4512,4514],{},[2863,4513,4038],{}," is for components that can wait a specific amount of time.",[4469,4516,4517,4519],{},[2863,4518,3802],{}," is for components that can be hydrated when the browser is idle.",[4469,4521,4522,4528],{},[4472,4523,4524,4525,4527],{},"Avoid ",[2863,4526,3703],{}," on interactive components:"," If a component requires user interaction, it should not be set to never hydrate.",[2983,4530,4532],{"id":4531},"direct-imports","Direct Imports",[2852,4534,4535,4536,4538],{},"You can also explicitly import components from ",[2863,4537,3234],{}," if you want or need to bypass Nuxt's auto-importing functionality.",[2856,4540,4542],{"className":3199,"code":4541,"filename":3245,"language":3200,"meta":2861,"style":2861},"\u003Cscript setup lang=\"ts\">\nimport { LazyMountainsList, NuxtLink } from '#components'\n\nconst show = ref(false)\n\u003C/script>\n\n\u003Ctemplate>\n  \u003Cdiv>\n    \u003Ch1>Mountains\u003C/h1>\n    \u003CLazyMountainsList v-if=\"show\" />\n    \u003Cbutton\n      v-if=\"!show\"\n      @click=\"show = true\"\n    >\n      Show List\n    \u003C/button>\n    \u003CNuxtLink to=\"/\">Home\u003C/NuxtLink>\n  \u003C/div>\n\u003C/template>\n",[2863,4543,4544,4564,4588,4592,4608,4616,4620,4628,4636,4652,4670,4676,4688,4700,4704,4708,4716,4747,4756],{"__ignoreMap":2861},[2866,4545,4546,4548,4550,4552,4554,4556,4558,4560,4562],{"class":2868,"line":2869},[2866,4547,2913],{"class":2876},[2866,4549,3254],{"class":2916},[2866,4551,3257],{"class":3211},[2866,4553,3260],{"class":3211},[2866,4555,3215],{"class":2876},[2866,4557,3218],{"class":2876},[2866,4559,3078],{"class":3130},[2866,4561,3218],{"class":2876},[2866,4563,2920],{"class":2876},[2866,4565,4566,4568,4570,4573,4575,4578,4580,4582,4584,4586],{"class":2868,"line":2883},[2866,4567,3275],{"class":3086},[2866,4569,3278],{"class":2876},[2866,4571,4572],{"class":3097}," LazyMountainsList",[2866,4574,3154],{"class":2876},[2866,4576,4577],{"class":3097}," NuxtLink",[2866,4579,3284],{"class":2876},[2866,4581,3287],{"class":3086},[2866,4583,3127],{"class":2876},[2866,4585,3234],{"class":3130},[2866,4587,3294],{"class":2876},[2866,4589,4590],{"class":2868,"line":2894},[2866,4591,3299],{"emptyLinePlaceholder":1196},[2866,4593,4594,4596,4598,4600,4602,4604,4606],{"class":2868,"line":2944},[2866,4595,3304],{"class":3211},[2866,4597,3518],{"class":3097},[2866,4599,3215],{"class":2876},[2866,4601,3523],{"class":3093},[2866,4603,3098],{"class":3097},[2866,4605,3072],{"class":3150},[2866,4607,3175],{"class":3097},[2866,4609,4610,4612,4614],{"class":2868,"line":2954},[2866,4611,2977],{"class":2876},[2866,4613,3254],{"class":2916},[2866,4615,2920],{"class":2876},[2866,4617,4618],{"class":2868,"line":2964},[2866,4619,3299],{"emptyLinePlaceholder":1196},[2866,4621,4622,4624,4626],{"class":2868,"line":2974},[2866,4623,2913],{"class":2876},[2866,4625,2917],{"class":2916},[2866,4627,2920],{"class":2876},[2866,4629,4630,4632,4634],{"class":2868,"line":3169},[2866,4631,2925],{"class":2876},[2866,4633,2928],{"class":2916},[2866,4635,2920],{"class":2876},[2866,4637,4638,4640,4642,4644,4646,4648,4650],{"class":2868,"line":3366},[2866,4639,2935],{"class":2876},[2866,4641,3564],{"class":2916},[2866,4643,3226],{"class":2876},[2866,4645,3569],{"class":3097},[2866,4647,2977],{"class":2876},[2866,4649,3564],{"class":2916},[2866,4651,2920],{"class":2876},[2866,4653,4654,4656,4658,4660,4662,4664,4666,4668],{"class":2868,"line":3386},[2866,4655,2935],{"class":2876},[2866,4657,3582],{"class":2916},[2866,4659,3585],{"class":3211},[2866,4661,3215],{"class":2876},[2866,4663,3218],{"class":2876},[2866,4665,3592],{"class":3130},[2866,4667,3218],{"class":2876},[2866,4669,2941],{"class":2876},[2866,4671,4672,4674],{"class":2868,"line":3621},[2866,4673,2935],{"class":2876},[2866,4675,3603],{"class":2916},[2866,4677,4678,4680,4682,4684,4686],{"class":2868,"line":3636},[2866,4679,3608],{"class":3211},[2866,4681,3215],{"class":2876},[2866,4683,3218],{"class":2876},[2866,4685,3615],{"class":3130},[2866,4687,3618],{"class":2876},[2866,4689,4690,4692,4694,4696,4698],{"class":2868,"line":3642},[2866,4691,3624],{"class":3211},[2866,4693,3215],{"class":2876},[2866,4695,3218],{"class":2876},[2866,4697,3631],{"class":3130},[2866,4699,3618],{"class":2876},[2866,4701,4702],{"class":2868,"line":3648},[2866,4703,3639],{"class":2876},[2866,4705,4706],{"class":2868,"line":3659},[2866,4707,3645],{"class":3097},[2866,4709,4710,4712,4714],{"class":2868,"line":3668},[2866,4711,3651],{"class":2876},[2866,4713,3654],{"class":2916},[2866,4715,2920],{"class":2876},[2866,4717,4719,4721,4724,4727,4729,4731,4734,4736,4738,4741,4743,4745],{"class":2868,"line":4718},17,[2866,4720,2935],{"class":2876},[2866,4722,4723],{"class":2916},"NuxtLink",[2866,4725,4726],{"class":3211}," to",[2866,4728,3215],{"class":2876},[2866,4730,3218],{"class":2876},[2866,4732,4733],{"class":3130},"/",[2866,4735,3218],{"class":2876},[2866,4737,3226],{"class":2876},[2866,4739,4740],{"class":3097},"Home",[2866,4742,2977],{"class":2876},[2866,4744,4723],{"class":2916},[2866,4746,2920],{"class":2876},[2866,4748,4750,4752,4754],{"class":2868,"line":4749},18,[2866,4751,2967],{"class":2876},[2866,4753,2928],{"class":2916},[2866,4755,2920],{"class":2876},[2866,4757,4759,4761,4763],{"class":2868,"line":4758},19,[2866,4760,2977],{"class":2876},[2866,4762,2917],{"class":2916},[2866,4764,2920],{"class":2876},[2983,4766,4768],{"id":4767},"custom-directories","Custom Directories",[2852,4770,4771,4772,4774],{},"By default, only the ",[2863,4773,3131],{}," directory is scanned. If you want to add other directories, or change how the components are scanned within a subfolder of this directory, you can add additional directories to the configuration:",[2856,4776,4779],{"className":4777,"code":4778,"filename":233,"language":3078,"meta":3079,"style":2861},"language-ts shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","export default defineNuxtConfig({\n  components: [\n    // ~/calendar-module/components/event/Update.vue => \u003CEventUpdate />\n    { path: '~/calendar-module/components' },\n\n    // ~/user-module/components/account/UserDeleteDialog.vue => \u003CUserDeleteDialog />\n    { path: '~/user-module/components', pathPrefix: false },\n\n    // ~/components/special-components/Btn.vue => \u003CSpecialBtn />\n    { path: '~/components/special-components', prefix: 'Special' },\n\n    // It's important that this comes last if you have overrides you wish to apply\n    // to sub-directories of `~/components`.\n    //\n    // ~/components/Btn.vue => \u003CBtn />\n    // ~/components/base/Btn.vue => \u003CBaseBtn />\n    '~/components',\n  ],\n})\n",[2863,4780,4781,4793,4801,4806,4826,4830,4835,4861,4865,4870,4901,4905,4910,4915,4920,4925,4930,4941,4947],{"__ignoreMap":2861},[2866,4782,4783,4785,4787,4789,4791],{"class":2868,"line":2869},[2866,4784,3087],{"class":3086},[2866,4786,3090],{"class":3086},[2866,4788,3094],{"class":3093},[2866,4790,3098],{"class":3097},[2866,4792,3101],{"class":2876},[2866,4794,4795,4797,4799],{"class":2868,"line":2883},[2866,4796,3106],{"class":2916},[2866,4798,3109],{"class":2876},[2866,4800,3112],{"class":3097},[2866,4802,4803],{"class":2868,"line":2894},[2866,4804,4805],{"class":4225},"    // ~/calendar-module/components/event/Update.vue => \u003CEventUpdate />\n",[2866,4807,4808,4811,4814,4816,4818,4821,4823],{"class":2868,"line":2944},[2866,4809,4810],{"class":2876},"    {",[2866,4812,4813],{"class":2916}," path",[2866,4815,3109],{"class":2876},[2866,4817,3127],{"class":2876},[2866,4819,4820],{"class":3130},"~/calendar-module/components",[2866,4822,3134],{"class":2876},[2866,4824,4825],{"class":2876}," },\n",[2866,4827,4828],{"class":2868,"line":2954},[2866,4829,3299],{"emptyLinePlaceholder":1196},[2866,4831,4832],{"class":2868,"line":2964},[2866,4833,4834],{"class":4225},"    // ~/user-module/components/account/UserDeleteDialog.vue => \u003CUserDeleteDialog />\n",[2866,4836,4837,4839,4841,4843,4845,4848,4850,4852,4855,4857,4859],{"class":2868,"line":2974},[2866,4838,4810],{"class":2876},[2866,4840,4813],{"class":2916},[2866,4842,3109],{"class":2876},[2866,4844,3127],{"class":2876},[2866,4846,4847],{"class":3130},"~/user-module/components",[2866,4849,3134],{"class":2876},[2866,4851,3154],{"class":2876},[2866,4853,4854],{"class":2916}," pathPrefix",[2866,4856,3109],{"class":2876},[2866,4858,3151],{"class":3150},[2866,4860,4825],{"class":2876},[2866,4862,4863],{"class":2868,"line":3169},[2866,4864,3299],{"emptyLinePlaceholder":1196},[2866,4866,4867],{"class":2868,"line":3366},[2866,4868,4869],{"class":4225},"    // ~/components/special-components/Btn.vue => \u003CSpecialBtn />\n",[2866,4871,4872,4874,4876,4878,4880,4883,4885,4887,4890,4892,4894,4897,4899],{"class":2868,"line":3386},[2866,4873,4810],{"class":2876},[2866,4875,4813],{"class":2916},[2866,4877,3109],{"class":2876},[2866,4879,3127],{"class":2876},[2866,4881,4882],{"class":3130},"~/components/special-components",[2866,4884,3134],{"class":2876},[2866,4886,3154],{"class":2876},[2866,4888,4889],{"class":2916}," prefix",[2866,4891,3109],{"class":2876},[2866,4893,3127],{"class":2876},[2866,4895,4896],{"class":3130},"Special",[2866,4898,3134],{"class":2876},[2866,4900,4825],{"class":2876},[2866,4902,4903],{"class":2868,"line":3621},[2866,4904,3299],{"emptyLinePlaceholder":1196},[2866,4906,4907],{"class":2868,"line":3636},[2866,4908,4909],{"class":4225},"    // It's important that this comes last if you have overrides you wish to apply\n",[2866,4911,4912],{"class":2868,"line":3642},[2866,4913,4914],{"class":4225},"    // to sub-directories of `~/components`.\n",[2866,4916,4917],{"class":2868,"line":3648},[2866,4918,4919],{"class":4225},"    //\n",[2866,4921,4922],{"class":2868,"line":3659},[2866,4923,4924],{"class":4225},"    // ~/components/Btn.vue => \u003CBtn />\n",[2866,4926,4927],{"class":2868,"line":3668},[2866,4928,4929],{"class":4225},"    // ~/components/base/Btn.vue => \u003CBaseBtn />\n",[2866,4931,4932,4935,4937,4939],{"class":2868,"line":4718},[2866,4933,4934],{"class":2876},"    '",[2866,4936,3131],{"class":3130},[2866,4938,3134],{"class":2876},[2866,4940,3137],{"class":2876},[2866,4942,4943,4945],{"class":2868,"line":4749},[2866,4944,3164],{"class":3097},[2866,4946,3137],{"class":2876},[2866,4948,4949,4951],{"class":2868,"line":4758},[2866,4950,3172],{"class":2876},[2866,4952,3175],{"class":3097},[3050,4954,4955],{},[2852,4956,4957],{},"Any nested directories need to be added first as they are scanned in order.",[2983,4959,4961],{"id":4960},"npm-packages","npm Packages",[2852,4963,4964,4965,4971,4972,4975],{},"If you want to auto-import components from an npm package, you can use ",[3791,4966,4968],{"href":4967},"/docs/3.x/api/kit/components#addcomponent",[2863,4969,4970],{},"addComponent"," in a ",[3791,4973,4974],{"href":163},"local module"," to register them.",[4977,4978,4979,5115],"code-group",{},[2856,4980,4983],{"className":4777,"code":4981,"filename":4982,"language":3078,"meta":3079,"style":2861},"import { addComponent, defineNuxtModule } from '@nuxt/kit'\n\nexport default defineNuxtModule({\n  setup () {\n    // import { MyComponent as MyAutoImportedComponent } from 'my-npm-package'\n    addComponent({\n      name: 'MyAutoImportedComponent',\n      export: 'MyComponent',\n      filePath: 'my-npm-package',\n    })\n  },\n})\n","~/modules/register-component.ts",[2863,4984,4985,5010,5014,5026,5035,5040,5049,5065,5081,5097,5104,5109],{"__ignoreMap":2861},[2866,4986,4987,4989,4991,4994,4996,4999,5001,5003,5005,5008],{"class":2868,"line":2869},[2866,4988,3275],{"class":3086},[2866,4990,3278],{"class":2876},[2866,4992,4993],{"class":3097}," addComponent",[2866,4995,3154],{"class":2876},[2866,4997,4998],{"class":3097}," defineNuxtModule",[2866,5000,3284],{"class":2876},[2866,5002,3287],{"class":3086},[2866,5004,3127],{"class":2876},[2866,5006,5007],{"class":3130},"@nuxt/kit",[2866,5009,3294],{"class":2876},[2866,5011,5012],{"class":2868,"line":2883},[2866,5013,3299],{"emptyLinePlaceholder":1196},[2866,5015,5016,5018,5020,5022,5024],{"class":2868,"line":2894},[2866,5017,3087],{"class":3086},[2866,5019,3090],{"class":3086},[2866,5021,4998],{"class":3093},[2866,5023,3098],{"class":3097},[2866,5025,3101],{"class":2876},[2866,5027,5028,5031,5033],{"class":2868,"line":2944},[2866,5029,5030],{"class":2916},"  setup",[2866,5032,4217],{"class":2876},[2866,5034,4220],{"class":2876},[2866,5036,5037],{"class":2868,"line":2954},[2866,5038,5039],{"class":4225},"    // import { MyComponent as MyAutoImportedComponent } from 'my-npm-package'\n",[2866,5041,5042,5045,5047],{"class":2868,"line":2964},[2866,5043,5044],{"class":3093},"    addComponent",[2866,5046,3098],{"class":2916},[2866,5048,3101],{"class":2876},[2866,5050,5051,5054,5056,5058,5061,5063],{"class":2868,"line":2974},[2866,5052,5053],{"class":2916},"      name",[2866,5055,3109],{"class":2876},[2866,5057,3127],{"class":2876},[2866,5059,5060],{"class":3130},"MyAutoImportedComponent",[2866,5062,3134],{"class":2876},[2866,5064,3137],{"class":2876},[2866,5066,5067,5070,5072,5074,5077,5079],{"class":2868,"line":3169},[2866,5068,5069],{"class":2916},"      export",[2866,5071,3109],{"class":2876},[2866,5073,3127],{"class":2876},[2866,5075,5076],{"class":3130},"MyComponent",[2866,5078,3134],{"class":2876},[2866,5080,3137],{"class":2876},[2866,5082,5083,5086,5088,5090,5093,5095],{"class":2868,"line":3366},[2866,5084,5085],{"class":2916},"      filePath",[2866,5087,3109],{"class":2876},[2866,5089,3127],{"class":2876},[2866,5091,5092],{"class":3130},"my-npm-package",[2866,5094,3134],{"class":2876},[2866,5096,3137],{"class":2876},[2866,5098,5099,5102],{"class":2868,"line":3386},[2866,5100,5101],{"class":2876},"    }",[2866,5103,3175],{"class":2916},[2866,5105,5106],{"class":2868,"line":3621},[2866,5107,5108],{"class":2876},"  },\n",[2866,5110,5111,5113],{"class":2868,"line":3636},[2866,5112,3172],{"class":2876},[2866,5114,3175],{"class":3097},[2856,5116,5118],{"className":3199,"code":5117,"filename":219,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!--  the component uses the name we specified and is auto-imported  -->\n    \u003CMyAutoImportedComponent />\n  \u003C/div>\n\u003C/template>\n",[2863,5119,5120,5128,5136,5141,5149,5157],{"__ignoreMap":2861},[2866,5121,5122,5124,5126],{"class":2868,"line":2869},[2866,5123,2913],{"class":2876},[2866,5125,2917],{"class":2916},[2866,5127,2920],{"class":2876},[2866,5129,5130,5132,5134],{"class":2868,"line":2883},[2866,5131,2925],{"class":2876},[2866,5133,2928],{"class":2916},[2866,5135,2920],{"class":2876},[2866,5137,5138],{"class":2868,"line":2894},[2866,5139,5140],{"class":4225},"    \u003C!--  the component uses the name we specified and is auto-imported  -->\n",[2866,5142,5143,5145,5147],{"class":2868,"line":2944},[2866,5144,2935],{"class":2876},[2866,5146,5060],{"class":2916},[2866,5148,2941],{"class":2876},[2866,5150,5151,5153,5155],{"class":2868,"line":2954},[2866,5152,2967],{"class":2876},[2866,5154,2928],{"class":2916},[2866,5156,2920],{"class":2876},[2866,5158,5159,5161,5163],{"class":2868,"line":2964},[2866,5160,2977],{"class":2876},[2866,5162,2917],{"class":2916},[2866,5164,2920],{"class":2876},[2983,5166,5168],{"id":5167},"component-extensions","Component Extensions",[2852,5170,5171,5172,5178,5179,5182],{},"By default, any file with an extension specified in the ",[3791,5173,5175,5176],{"href":5174},"/docs/3.x/api/nuxt-config#extensions","extensions key of ",[2863,5177,233],{}," is treated as a component.\nIf you need to restrict the file extensions that should be registered as components, you can use the extended form of the components directory declaration and its ",[2863,5180,5181],{},"extensions"," key:",[2856,5184,5186],{"className":3076,"code":5185,"filename":233,"language":3078,"meta":3079,"style":2861},"export default defineNuxtConfig({\n  components: [\n    {\n      path: '~/components',\n      extensions: ['.vue'], // [!code ++]\n    },\n  ],\n})\n",[2863,5187,5188,5200,5208,5212,5226,5249,5253,5259],{"__ignoreMap":2861},[2866,5189,5190,5192,5194,5196,5198],{"class":2868,"line":2869},[2866,5191,3087],{"class":3086},[2866,5193,3090],{"class":3086},[2866,5195,3094],{"class":3093},[2866,5197,3098],{"class":3097},[2866,5199,3101],{"class":2876},[2866,5201,5202,5204,5206],{"class":2868,"line":2883},[2866,5203,3106],{"class":2916},[2866,5205,3109],{"class":2876},[2866,5207,3112],{"class":3097},[2866,5209,5210],{"class":2868,"line":2894},[2866,5211,3117],{"class":2876},[2866,5213,5214,5216,5218,5220,5222,5224],{"class":2868,"line":2944},[2866,5215,3122],{"class":2916},[2866,5217,3109],{"class":2876},[2866,5219,3127],{"class":2876},[2866,5221,3131],{"class":3130},[2866,5223,3134],{"class":2876},[2866,5225,3137],{"class":2876},[2866,5227,5229,5232,5234,5237,5239,5242,5244,5247],{"class":5228,"line":2954},[2868,3141,3142],[2866,5230,5231],{"class":2916},"      extensions",[2866,5233,3109],{"class":2876},[2866,5235,5236],{"class":3097}," [",[2866,5238,3134],{"class":2876},[2866,5240,5241],{"class":3130},".vue",[2866,5243,3134],{"class":2876},[2866,5245,5246],{"class":3097},"]",[2866,5248,3154],{"class":2876},[2866,5250,5251],{"class":2868,"line":2964},[2866,5252,3159],{"class":2876},[2866,5254,5255,5257],{"class":2868,"line":2974},[2866,5256,3164],{"class":3097},[2866,5258,3137],{"class":2876},[2866,5260,5261,5263],{"class":2868,"line":3169},[2866,5262,3172],{"class":2876},[2866,5264,3175],{"class":3097},[2983,5266,5268],{"id":5267},"client-components","Client Components",[2852,5270,5271,5272,5275],{},"If a component is meant to be rendered only client-side, you can add the ",[2863,5273,5274],{},".client"," suffix to your component.",[2856,5277,5279],{"className":2858,"code":5278,"filename":110,"language":2860,"meta":2861,"style":2861},"| components/\n--| Comments.client.vue\n",[2863,5280,5281,5287],{"__ignoreMap":2861},[2866,5282,5283,5285],{"class":2868,"line":2869},[2866,5284,2877],{"class":2876},[2866,5286,2880],{"class":2872},[2866,5288,5289,5292,5294],{"class":2868,"line":2883},[2866,5290,5291],{"class":2872},"--",[2866,5293,2877],{"class":2876},[2866,5295,5296],{"class":2872}," Comments.client.vue\n",[2856,5298,5301],{"className":3199,"code":5299,"filename":5300,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!-- this component will only be rendered on client side -->\n    \u003CComments />\n  \u003C/div>\n\u003C/template>\n","pages/example.vue",[2863,5302,5303,5311,5319,5324,5333,5341],{"__ignoreMap":2861},[2866,5304,5305,5307,5309],{"class":2868,"line":2869},[2866,5306,2913],{"class":2876},[2866,5308,2917],{"class":2916},[2866,5310,2920],{"class":2876},[2866,5312,5313,5315,5317],{"class":2868,"line":2883},[2866,5314,2925],{"class":2876},[2866,5316,2928],{"class":2916},[2866,5318,2920],{"class":2876},[2866,5320,5321],{"class":2868,"line":2894},[2866,5322,5323],{"class":4225},"    \u003C!-- this component will only be rendered on client side -->\n",[2866,5325,5326,5328,5331],{"class":2868,"line":2944},[2866,5327,2935],{"class":2876},[2866,5329,5330],{"class":2916},"Comments",[2866,5332,2941],{"class":2876},[2866,5334,5335,5337,5339],{"class":2868,"line":2954},[2866,5336,2967],{"class":2876},[2866,5338,2928],{"class":2916},[2866,5340,2920],{"class":2876},[2866,5342,5343,5345,5347],{"class":2868,"line":2964},[2866,5344,2977],{"class":2876},[2866,5346,2917],{"class":2916},[2866,5348,2920],{"class":2876},[3050,5350,5351],{},[2852,5352,5353,5354,5356],{},"This feature only works with Nuxt auto-imports and ",[2863,5355,3234],{}," imports. Explicitly importing these components from their real paths does not convert them into client-only components.",[3394,5358,5359],{},[2852,5360,5361,5363,5364,5367,5368,5371,5372,5374],{},[2863,5362,5274],{}," components are rendered only after being mounted. To access the rendered template using ",[2863,5365,5366],{},"onMounted()",", add ",[2863,5369,5370],{},"await nextTick()"," in the callback of the ",[2863,5373,5366],{}," hook.",[3776,5376,5377],{"to":441},[2852,5378,5379,5380,5382],{},"You can also achieve a similar result with the ",[2863,5381,440],{}," component.",[2983,5384,5386],{"id":5385},"server-components","Server Components",[2852,5388,5389],{},"Server components allow server-rendering individual components within your client-side apps. It's possible to use server components within Nuxt, even if you are generating a static site. That makes it possible to build complex sites that mix dynamic components, server-rendered HTML and even static chunks of markup.",[2852,5391,5392,5393,3062],{},"Server components can either be used on their own or paired with a ",[3791,5394,5396],{"href":5395},"/docs/3.x/directory-structure/components#paired-with-a-client-component","client component",[3403,5398],{"title":5399,"video-id":5400},"Watch Learn Vue video about Nuxt Server Components","u1yyXe86xJM",[5402,5403,5407],"tip",{"icon":5404,"target":5405,"to":5406},"i-lucide-newspaper","_blank","https://roe.dev/blog/nuxt-server-components",[2852,5408,5409],{},"Read Daniel Roe's guide to Nuxt Server Components.",[3689,5411,5413],{"id":5412},"standalone-server-components","Standalone server components",[2852,5415,5416],{},"Standalone server components will always be rendered on the server, also known as Islands components.",[2852,5418,5419],{},"When their props update, this will result in a network request that will update the rendered HTML in-place.",[2852,5421,5422],{},"Server components are currently experimental and in order to use them, you need to enable the 'component islands' feature in your nuxt.config:",[2856,5424,5426],{"className":4777,"code":5425,"filename":233,"language":3078,"meta":3079,"style":2861},"export default defineNuxtConfig({\n  experimental: {\n    componentIslands: true,\n  },\n})\n",[2863,5427,5428,5440,5449,5461,5465],{"__ignoreMap":2861},[2866,5429,5430,5432,5434,5436,5438],{"class":2868,"line":2869},[2866,5431,3087],{"class":3086},[2866,5433,3090],{"class":3086},[2866,5435,3094],{"class":3093},[2866,5437,3098],{"class":3097},[2866,5439,3101],{"class":2876},[2866,5441,5442,5445,5447],{"class":2868,"line":2883},[2866,5443,5444],{"class":2916},"  experimental",[2866,5446,3109],{"class":2876},[2866,5448,4220],{"class":2876},[2866,5450,5451,5454,5456,5459],{"class":2868,"line":2894},[2866,5452,5453],{"class":2916},"    componentIslands",[2866,5455,3109],{"class":2876},[2866,5457,5458],{"class":3150}," true",[2866,5460,3137],{"class":2876},[2866,5462,5463],{"class":2868,"line":2944},[2866,5464,5108],{"class":2876},[2866,5466,5467,5469],{"class":2868,"line":2954},[2866,5468,3172],{"class":2876},[2866,5470,3175],{"class":3097},[2852,5472,5473,5474,5477],{},"Now you can register server-only components with the ",[2863,5475,5476],{},".server"," suffix and use them anywhere in your application automatically.",[2856,5479,5481],{"className":2858,"code":5480,"filename":110,"language":2860,"meta":2861,"style":2861},"-| components/\n---| HighlightedMarkdown.server.vue\n",[2863,5482,5483,5491],{"__ignoreMap":2861},[2866,5484,5485,5487,5489],{"class":2868,"line":2869},[2866,5486,2873],{"class":2872},[2866,5488,2877],{"class":2876},[2866,5490,2880],{"class":2872},[2866,5492,5493,5495,5497],{"class":2868,"line":2883},[2866,5494,2886],{"class":2872},[2866,5496,2877],{"class":2876},[2866,5498,5499],{"class":2872}," HighlightedMarkdown.server.vue\n",[2856,5501,5503],{"className":3199,"code":5502,"filename":5300,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!--\n      this will automatically be rendered on the server, meaning your markdown parsing + highlighting\n      libraries are not included in your client bundle.\n     -->\n    \u003CHighlightedMarkdown markdown=\"# Headline\" />\n  \u003C/div>\n\u003C/template>\n",[2863,5504,5505,5513,5521,5526,5531,5536,5541,5562,5570],{"__ignoreMap":2861},[2866,5506,5507,5509,5511],{"class":2868,"line":2869},[2866,5508,2913],{"class":2876},[2866,5510,2917],{"class":2916},[2866,5512,2920],{"class":2876},[2866,5514,5515,5517,5519],{"class":2868,"line":2883},[2866,5516,2925],{"class":2876},[2866,5518,2928],{"class":2916},[2866,5520,2920],{"class":2876},[2866,5522,5523],{"class":2868,"line":2894},[2866,5524,5525],{"class":4225},"    \u003C!--\n",[2866,5527,5528],{"class":2868,"line":2944},[2866,5529,5530],{"class":4225},"      this will automatically be rendered on the server, meaning your markdown parsing + highlighting\n",[2866,5532,5533],{"class":2868,"line":2954},[2866,5534,5535],{"class":4225},"      libraries are not included in your client bundle.\n",[2866,5537,5538],{"class":2868,"line":2964},[2866,5539,5540],{"class":4225},"     -->\n",[2866,5542,5543,5545,5548,5551,5553,5555,5558,5560],{"class":2868,"line":2974},[2866,5544,2935],{"class":2876},[2866,5546,5547],{"class":2916},"HighlightedMarkdown",[2866,5549,5550],{"class":3211}," markdown",[2866,5552,3215],{"class":2876},[2866,5554,3218],{"class":2876},[2866,5556,5557],{"class":3130},"# Headline",[2866,5559,3218],{"class":2876},[2866,5561,2941],{"class":2876},[2866,5563,5564,5566,5568],{"class":2868,"line":3169},[2866,5565,2967],{"class":2876},[2866,5567,2928],{"class":2916},[2866,5569,2920],{"class":2876},[2866,5571,5572,5574,5576],{"class":2868,"line":3366},[2866,5573,2977],{"class":2876},[2866,5575,2917],{"class":2916},[2866,5577,2920],{"class":2876},[2852,5579,5580,5581,5585,5586,5589,5590,5593],{},"Server-only components use ",[3791,5582,5583],{"href":493},[2863,5584,492],{}," under the hood, meaning that ",[2863,5587,5588],{},"lazy"," prop and ",[2863,5591,5592],{},"#fallback"," slot are both passed down to it.",[3706,5595,5596],{},[2852,5597,5598],{},"Server components (and islands) must have a single root element. (HTML comments are considered elements as well.)",[3706,5600,5601],{},[2852,5602,5603],{},"Props are passed to server components via URL query parameters, and are therefore limited by the possible length of a URL, so be careful not to pass enormous amounts of data to server components via props.",[3706,5605,5606],{},[2852,5607,5608],{},"Be careful when nesting islands within other islands as each island adds some extra overhead.",[3706,5610,5611],{},[2852,5612,5613],{},"Most features for server-only components and island components, such as slots and client components, are only available for single file components.",[3718,5615,5617],{"id":5616},"client-components-within-server-components","Client components within server components",[3050,5619,5620],{},[2852,5621,5622,5623,5626],{},"This feature needs ",[2863,5624,5625],{},"experimental.componentIslands.selectiveClient"," within your configuration to be true.",[2852,5628,5629,5630,5633],{},"You can partially hydrate a component by setting a ",[2863,5631,5632],{},"nuxt-client"," attribute on the component you wish to be loaded client-side.",[2856,5635,5638],{"className":3199,"code":5636,"filename":5637,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CHighlightedMarkdown markdown=\"# Headline\" />\n    \u003C!-- Counter will be loaded and hydrated client-side -->\n    \u003CCounter\n      nuxt-client\n      :count=\"5\"\n    />\n  \u003C/div>\n\u003C/template>\n","components/ServerWithClient.vue",[2863,5639,5640,5648,5656,5674,5679,5686,5691,5705,5709,5717],{"__ignoreMap":2861},[2866,5641,5642,5644,5646],{"class":2868,"line":2869},[2866,5643,2913],{"class":2876},[2866,5645,2917],{"class":2916},[2866,5647,2920],{"class":2876},[2866,5649,5650,5652,5654],{"class":2868,"line":2883},[2866,5651,2925],{"class":2876},[2866,5653,2928],{"class":2916},[2866,5655,2920],{"class":2876},[2866,5657,5658,5660,5662,5664,5666,5668,5670,5672],{"class":2868,"line":2894},[2866,5659,2935],{"class":2876},[2866,5661,5547],{"class":2916},[2866,5663,5550],{"class":3211},[2866,5665,3215],{"class":2876},[2866,5667,3218],{"class":2876},[2866,5669,5557],{"class":3130},[2866,5671,3218],{"class":2876},[2866,5673,2941],{"class":2876},[2866,5675,5676],{"class":2868,"line":2944},[2866,5677,5678],{"class":4225},"    \u003C!-- Counter will be loaded and hydrated client-side -->\n",[2866,5680,5681,5683],{"class":2868,"line":2954},[2866,5682,2935],{"class":2876},[2866,5684,5685],{"class":2916},"Counter\n",[2866,5687,5688],{"class":2868,"line":2964},[2866,5689,5690],{"class":3211},"      nuxt-client\n",[2866,5692,5693,5696,5698,5700,5703],{"class":2868,"line":2974},[2866,5694,5695],{"class":3211},"      :count",[2866,5697,3215],{"class":2876},[2866,5699,3218],{"class":2876},[2866,5701,5702],{"class":3130},"5",[2866,5704,3618],{"class":2876},[2866,5706,5707],{"class":2868,"line":3169},[2866,5708,4373],{"class":2876},[2866,5710,5711,5713,5715],{"class":2868,"line":3366},[2866,5712,2967],{"class":2876},[2866,5714,2928],{"class":2916},[2866,5716,2920],{"class":2876},[2866,5718,5719,5721,5723],{"class":2868,"line":3386},[2866,5720,2977],{"class":2876},[2866,5722,2917],{"class":2916},[2866,5724,2920],{"class":2876},[3050,5726,5727],{},[2852,5728,5729,5730,5733,5734,5737],{},"This only works within a server component. Slots for client components are working only with ",[2863,5731,5732],{},"experimental.componentIsland.selectiveClient"," set to ",[2863,5735,5736],{},"'deep'"," and since they are rendered server-side, they are not interactive once client-side.",[3718,5739,5741],{"id":5740},"server-component-context","Server Component Context",[2852,5743,5744,5745,5747,5748,5751],{},"When rendering a server-only or island component, ",[2863,5746,492],{}," makes a fetch request which comes back with a ",[2863,5749,5750],{},"NuxtIslandResponse",". (This is an internal request if rendered on the server, or a request that you can see in the network tab if it's rendering on client-side navigation.)",[2852,5753,5754],{},"This means:",[4503,5756,5757,5762,5765,5773],{},[4469,5758,5759,5760,3062],{},"A new Vue app will be created server-side to create the ",[2863,5761,5750],{},[4469,5763,5764],{},"A new 'island context' will be created while rendering the component.",[4469,5766,5767,5768,5772],{},"You can't access the 'island context' from the rest of your app and you can't access the context of the rest of your app from the island component. In other words, the server component or island is ",[5769,5770,5771],"em",{},"isolated"," from the rest of your app.",[4469,5774,5775,5776,5779],{},"Your plugins will run again when rendering the island, unless they have ",[2863,5777,5778],{},"env: { islands: false }"," set (which you can do in an object-syntax plugin).",[3394,5781,5782],{},[2852,5783,5784],{},"Route middleware does not run when rendering island components. Middleware is a routing concept that applies to pages, not components, and is not designed to control component rendering.",[2852,5786,5787,5788,5791],{},"Within an island component, you can access its island context through ",[2863,5789,5790],{},"nuxtApp.ssrContext.islandContext",". Note that while island components are still marked as experimental, the format of this context may change.",[3050,5793,5794],{},[2852,5795,5796,5797,5800,5801],{},"Slots can be interactive and are wrapped within a ",[2863,5798,5799],{},"\u003Cdiv>"," with ",[2863,5802,5803],{},"display: contents;",[3689,5805,5807],{"id":5806},"paired-with-a-client-component","Paired with a Client component",[2852,5809,5810,5811,5813,5814,5816],{},"In this case, the ",[2863,5812,5476],{}," + ",[2863,5815,5274],{}," components are two 'halves' of a component and can be used in advanced use cases for separate implementations of a component on server and client side.",[2856,5818,5820],{"className":2858,"code":5819,"filename":110,"language":2860,"meta":2861,"style":2861},"-| components/\n---| Comments.client.vue\n---| Comments.server.vue\n",[2863,5821,5822,5830,5838],{"__ignoreMap":2861},[2866,5823,5824,5826,5828],{"class":2868,"line":2869},[2866,5825,2873],{"class":2872},[2866,5827,2877],{"class":2876},[2866,5829,2880],{"class":2872},[2866,5831,5832,5834,5836],{"class":2868,"line":2883},[2866,5833,2886],{"class":2872},[2866,5835,2877],{"class":2876},[2866,5837,5296],{"class":2872},[2866,5839,5840,5842,5844],{"class":2868,"line":2894},[2866,5841,2886],{"class":2872},[2866,5843,2877],{"class":2876},[2866,5845,5846],{"class":2872}," Comments.server.vue\n",[2856,5848,5850],{"className":3199,"code":5849,"filename":5300,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!-- this component will render Comments.server on the server then Comments.client once mounted in the browser -->\n    \u003CComments />\n  \u003C/div>\n\u003C/template>\n",[2863,5851,5852,5860,5868,5873,5881,5889],{"__ignoreMap":2861},[2866,5853,5854,5856,5858],{"class":2868,"line":2869},[2866,5855,2913],{"class":2876},[2866,5857,2917],{"class":2916},[2866,5859,2920],{"class":2876},[2866,5861,5862,5864,5866],{"class":2868,"line":2883},[2866,5863,2925],{"class":2876},[2866,5865,2928],{"class":2916},[2866,5867,2920],{"class":2876},[2866,5869,5870],{"class":2868,"line":2894},[2866,5871,5872],{"class":4225},"    \u003C!-- this component will render Comments.server on the server then Comments.client once mounted in the browser -->\n",[2866,5874,5875,5877,5879],{"class":2868,"line":2944},[2866,5876,2935],{"class":2876},[2866,5878,5330],{"class":2916},[2866,5880,2941],{"class":2876},[2866,5882,5883,5885,5887],{"class":2868,"line":2954},[2866,5884,2967],{"class":2876},[2866,5886,2928],{"class":2916},[2866,5888,2920],{"class":2876},[2866,5890,5891,5893,5895],{"class":2868,"line":2964},[2866,5892,2977],{"class":2876},[2866,5894,2917],{"class":2916},[2866,5896,2920],{"class":2876},[2983,5898,5900],{"id":5899},"built-in-nuxt-components","Built-In Nuxt Components",[2852,5902,5903,5904,3945,5906,5908],{},"There are a number of components that Nuxt provides, including ",[2863,5905,440],{},[2863,5907,444],{},". You can read more about them in the API documentation.",[3776,5910],{"to":430},[2983,5912,5914],{"id":5913},"library-authors","Library Authors",[2852,5916,5917],{},"Making Vue component libraries with automatic tree-shaking and component registration is super easy. ✨",[2852,5919,5920,5921,5927,5928,5930],{},"You can use the ",[3791,5922,5924],{"href":5923},"/docs/3.x/api/kit/components#addcomponentsdir",[2863,5925,5926],{},"addComponentsDir"," method provided from the ",[2863,5929,5007],{}," to register your components directory in your Nuxt module.",[2852,5932,5933],{},"Imagine a directory structure like this:",[2856,5935,5937],{"className":2858,"code":5936,"filename":110,"language":2860,"meta":2861,"style":2861},"-| node_modules/\n---| awesome-ui/\n-----| components/\n-------| Alert.vue\n-------| Button.vue\n-----| nuxt.ts\n-| pages/\n---| index.vue\n-| nuxt.config.ts\n",[2863,5938,5939,5948,5957,5965,5974,5982,5991,6000,6009],{"__ignoreMap":2861},[2866,5940,5941,5943,5945],{"class":2868,"line":2869},[2866,5942,2873],{"class":2872},[2866,5944,2877],{"class":2876},[2866,5946,5947],{"class":2872}," node_modules/\n",[2866,5949,5950,5952,5954],{"class":2868,"line":2883},[2866,5951,2886],{"class":2872},[2866,5953,2877],{"class":2876},[2866,5955,5956],{"class":2872}," awesome-ui/\n",[2866,5958,5959,5961,5963],{"class":2868,"line":2894},[2866,5960,3016],{"class":2872},[2866,5962,2877],{"class":2876},[2866,5964,2880],{"class":2872},[2866,5966,5967,5969,5971],{"class":2868,"line":2944},[2866,5968,3026],{"class":2872},[2866,5970,2877],{"class":2876},[2866,5972,5973],{"class":2872}," Alert.vue\n",[2866,5975,5976,5978,5980],{"class":2868,"line":2954},[2866,5977,3026],{"class":2872},[2866,5979,2877],{"class":2876},[2866,5981,3031],{"class":2872},[2866,5983,5984,5986,5988],{"class":2868,"line":2964},[2866,5985,3016],{"class":2872},[2866,5987,2877],{"class":2876},[2866,5989,5990],{"class":2872}," nuxt.ts\n",[2866,5992,5993,5995,5997],{"class":2868,"line":2974},[2866,5994,2873],{"class":2872},[2866,5996,2877],{"class":2876},[2866,5998,5999],{"class":2872}," pages/\n",[2866,6001,6002,6004,6006],{"class":2868,"line":3169},[2866,6003,2886],{"class":2872},[2866,6005,2877],{"class":2876},[2866,6007,6008],{"class":2872}," index.vue\n",[2866,6010,6011,6013,6015],{"class":2868,"line":3366},[2866,6012,2873],{"class":2872},[2866,6014,2877],{"class":2876},[2866,6016,6017],{"class":2872}," nuxt.config.ts\n",[2852,6019,6020,6021,6024,6025,6027],{},"Then in ",[2863,6022,6023],{},"awesome-ui/nuxt.ts"," you can use the ",[2863,6026,5926],{}," hook:",[2856,6029,6031],{"className":4777,"code":6030,"language":3078,"meta":3079,"style":2861},"import { addComponentsDir, createResolver, defineNuxtModule } from '@nuxt/kit'\n\nexport default defineNuxtModule({\n  setup () {\n    const resolver = createResolver(import.meta.url)\n\n    // Add ./components dir to the list\n    addComponentsDir({\n      path: resolver.resolve('./components'),\n      prefix: 'awesome',\n    })\n  },\n})\n",[2863,6032,6033,6061,6065,6077,6085,6113,6117,6122,6131,6158,6174,6180,6184],{"__ignoreMap":2861},[2866,6034,6035,6037,6039,6042,6044,6047,6049,6051,6053,6055,6057,6059],{"class":2868,"line":2869},[2866,6036,3275],{"class":3086},[2866,6038,3278],{"class":2876},[2866,6040,6041],{"class":3097}," addComponentsDir",[2866,6043,3154],{"class":2876},[2866,6045,6046],{"class":3097}," createResolver",[2866,6048,3154],{"class":2876},[2866,6050,4998],{"class":3097},[2866,6052,3284],{"class":2876},[2866,6054,3287],{"class":3086},[2866,6056,3127],{"class":2876},[2866,6058,5007],{"class":3130},[2866,6060,3294],{"class":2876},[2866,6062,6063],{"class":2868,"line":2883},[2866,6064,3299],{"emptyLinePlaceholder":1196},[2866,6066,6067,6069,6071,6073,6075],{"class":2868,"line":2894},[2866,6068,3087],{"class":3086},[2866,6070,3090],{"class":3086},[2866,6072,4998],{"class":3093},[2866,6074,3098],{"class":3097},[2866,6076,3101],{"class":2876},[2866,6078,6079,6081,6083],{"class":2868,"line":2944},[2866,6080,5030],{"class":2916},[2866,6082,4217],{"class":2876},[2866,6084,4220],{"class":2876},[2866,6086,6087,6090,6093,6095,6097,6099,6101,6103,6106,6108,6111],{"class":2868,"line":2954},[2866,6088,6089],{"class":3211},"    const",[2866,6091,6092],{"class":3097}," resolver",[2866,6094,4239],{"class":2876},[2866,6096,6046],{"class":3093},[2866,6098,3098],{"class":2916},[2866,6100,3275],{"class":3086},[2866,6102,3062],{"class":2876},[2866,6104,6105],{"class":3097},"meta",[2866,6107,3062],{"class":2876},[2866,6109,6110],{"class":3097},"url",[2866,6112,3175],{"class":2916},[2866,6114,6115],{"class":2868,"line":2964},[2866,6116,3299],{"emptyLinePlaceholder":1196},[2866,6118,6119],{"class":2868,"line":2974},[2866,6120,6121],{"class":4225},"    // Add ./components dir to the list\n",[2866,6123,6124,6127,6129],{"class":2868,"line":3169},[2866,6125,6126],{"class":3093},"    addComponentsDir",[2866,6128,3098],{"class":2916},[2866,6130,3101],{"class":2876},[2866,6132,6133,6135,6137,6139,6141,6144,6146,6148,6151,6153,6156],{"class":2868,"line":3366},[2866,6134,3122],{"class":2916},[2866,6136,3109],{"class":2876},[2866,6138,6092],{"class":3097},[2866,6140,3062],{"class":2876},[2866,6142,6143],{"class":3093},"resolve",[2866,6145,3098],{"class":2916},[2866,6147,3134],{"class":2876},[2866,6149,6150],{"class":3130},"./components",[2866,6152,3134],{"class":2876},[2866,6154,6155],{"class":2916},")",[2866,6157,3137],{"class":2876},[2866,6159,6160,6163,6165,6167,6170,6172],{"class":2868,"line":3386},[2866,6161,6162],{"class":2916},"      prefix",[2866,6164,3109],{"class":2876},[2866,6166,3127],{"class":2876},[2866,6168,6169],{"class":3130},"awesome",[2866,6171,3134],{"class":2876},[2866,6173,3137],{"class":2876},[2866,6175,6176,6178],{"class":2868,"line":3621},[2866,6177,5101],{"class":2876},[2866,6179,3175],{"class":2916},[2866,6181,6182],{"class":2868,"line":3636},[2866,6183,5108],{"class":2876},[2866,6185,6186,6188],{"class":2868,"line":3642},[2866,6187,3172],{"class":2876},[2866,6189,3175],{"class":3097},[2852,6191,6192,6193,6196],{},"That's it! Now in your project, you can import your UI library as a Nuxt module in your ",[2863,6194,6195],{},"nuxt.config"," file:",[2856,6198,6200],{"className":4777,"code":6199,"filename":233,"language":3078,"meta":3079,"style":2861},"export default defineNuxtConfig({\n  modules: ['awesome-ui/nuxt'],\n})\n",[2863,6201,6202,6214,6234],{"__ignoreMap":2861},[2866,6203,6204,6206,6208,6210,6212],{"class":2868,"line":2869},[2866,6205,3087],{"class":3086},[2866,6207,3090],{"class":3086},[2866,6209,3094],{"class":3093},[2866,6211,3098],{"class":3097},[2866,6213,3101],{"class":2876},[2866,6215,6216,6219,6221,6223,6225,6228,6230,6232],{"class":2868,"line":2883},[2866,6217,6218],{"class":2916},"  modules",[2866,6220,3109],{"class":2876},[2866,6222,5236],{"class":3097},[2866,6224,3134],{"class":2876},[2866,6226,6227],{"class":3130},"awesome-ui/nuxt",[2866,6229,3134],{"class":2876},[2866,6231,5246],{"class":3097},[2866,6233,3137],{"class":2876},[2866,6235,6236,6238],{"class":2868,"line":2894},[2866,6237,3172],{"class":2876},[2866,6239,3175],{"class":3097},[2852,6241,6242,6243,6246,6247,3109],{},"... and directly use the module components (prefixed with ",[2863,6244,6245],{},"awesome-",") in our ",[2863,6248,3245],{},[2856,6250,6252],{"className":3199,"code":6251,"language":3200,"meta":2861,"style":2861},"\u003Ctemplate>\n  \u003Cdiv>\n    My \u003CAwesomeButton>UI button\u003C/AwesomeButton>!\n    \u003Cawesome-alert>Here's an alert!\u003C/awesome-alert>\n  \u003C/div>\n\u003C/template>\n",[2863,6253,6254,6262,6270,6294,6312,6320],{"__ignoreMap":2861},[2866,6255,6256,6258,6260],{"class":2868,"line":2869},[2866,6257,2913],{"class":2876},[2866,6259,2917],{"class":2916},[2866,6261,2920],{"class":2876},[2866,6263,6264,6266,6268],{"class":2868,"line":2883},[2866,6265,2925],{"class":2876},[2866,6267,2928],{"class":2916},[2866,6269,2920],{"class":2876},[2866,6271,6272,6275,6277,6280,6282,6285,6287,6289,6291],{"class":2868,"line":2894},[2866,6273,6274],{"class":3097},"    My ",[2866,6276,2913],{"class":2876},[2866,6278,6279],{"class":2916},"AwesomeButton",[2866,6281,3226],{"class":2876},[2866,6283,6284],{"class":3097},"UI button",[2866,6286,2977],{"class":2876},[2866,6288,6279],{"class":2916},[2866,6290,3226],{"class":2876},[2866,6292,6293],{"class":3097},"!\n",[2866,6295,6296,6298,6301,6303,6306,6308,6310],{"class":2868,"line":2944},[2866,6297,2935],{"class":2876},[2866,6299,6300],{"class":2916},"awesome-alert",[2866,6302,3226],{"class":2876},[2866,6304,6305],{"class":3097},"Here's an alert!",[2866,6307,2977],{"class":2876},[2866,6309,6300],{"class":2916},[2866,6311,2920],{"class":2876},[2866,6313,6314,6316,6318],{"class":2868,"line":2954},[2866,6315,2967],{"class":2876},[2866,6317,2928],{"class":2916},[2866,6319,2920],{"class":2876},[2866,6321,6322,6324,6326],{"class":2868,"line":2964},[2866,6323,2977],{"class":2876},[2866,6325,2917],{"class":2916},[2866,6327,2920],{"class":2876},[2852,6329,6330,6331,3062],{},"It will automatically import the components only if used and also support HMR when updating your components in ",[2863,6332,6333],{},"node_modules/awesome-ui/components/",[6335,6336],"link-example",{"to":923},[6338,6339,6340],"style",{},"html pre.shiki code .s52Pk, html code.shiki .s52Pk{--shiki-light:#E2931D;--shiki-default:#E2931D;--shiki-dark:#FFCB6B}html pre.shiki code .sDfIl, html code.shiki .sDfIl{--shiki-light:#39ADB5;--shiki-default:#39ADB5;--shiki-dark:#89DDFF}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 .sRlkE, html code.shiki .sRlkE{--shiki-light:#E53935;--shiki-default:#E53935;--shiki-dark:#F07178}html pre.shiki code .s8R28, html code.shiki .s8R28{--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 .s3cPz, html code.shiki .s3cPz{--shiki-light:#6182B8;--shiki-default:#6182B8;--shiki-dark:#82AAFF}html pre.shiki code .sZSNi, html code.shiki .sZSNi{--shiki-light:#90A4AE;--shiki-default:#90A4AE;--shiki-dark:#BABED8}html pre.shiki code .sGFVr, html code.shiki .sGFVr{--shiki-light:#91B859;--shiki-default:#91B859;--shiki-dark:#C3E88D}html pre.shiki code .sbKd-, html code.shiki .sbKd-{--shiki-light:#FF5370;--shiki-default:#FF5370;--shiki-dark:#FF9CAC}html pre.shiki code .smZ93, html code.shiki .smZ93{--shiki-light:#9C3EDA;--shiki-default:#9C3EDA;--shiki-dark:#C792EA}html pre.shiki code .sWuyu, html code.shiki .sWuyu{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#90A4AE;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}",{"title":2861,"searchDepth":2883,"depth":2883,"links":6342},[6343,6344,6345,6346,6351,6352,6353,6354,6355,6356,6360,6361],{"id":2985,"depth":2883,"text":2986},{"id":3192,"depth":2883,"text":3193},{"id":3472,"depth":2883,"text":3473},{"id":3677,"depth":2883,"text":3678,"children":6347},[6348,6349,6350],{"id":3691,"depth":2894,"text":3692},{"id":4313,"depth":2894,"text":4314},{"id":4460,"depth":2894,"text":4461},{"id":4531,"depth":2883,"text":4532},{"id":4767,"depth":2883,"text":4768},{"id":4960,"depth":2883,"text":4961},{"id":5167,"depth":2883,"text":5168},{"id":5267,"depth":2883,"text":5268},{"id":5385,"depth":2883,"text":5386,"children":6357},[6358,6359],{"id":5412,"depth":2894,"text":5413},{"id":5806,"depth":2894,"text":5807},{"id":5899,"depth":2883,"text":5900},{"id":5913,"depth":2883,"text":5914},"The components/ directory is where you put all your Vue components.","md",{"head":6365},{"title":6366},"components/",{"icon":135},{"title":132,"description":6362},"CurfJjvxwOzpaurvouKVBJYs7nljtVs5-Th6E31-Z2Q",[6371,6373],{"title":127,"path":128,"stem":129,"description":6372,"icon":130,"children":-1},"The assets/ directory is used to add all the website's assets that the build tool will process.",{"title":137,"path":138,"stem":139,"description":6374,"icon":140,"children":-1},"Use the composables/ directory to auto-import your Vue composables into your application.",1772452356162]